当前位置: 首页 > news >正文

山西p2p网站建设wordpress迁移器

山西p2p网站建设,wordpress迁移器,wordpress 归档文章,网页制作软件序列号并查集前言一、按字典序排列的最小的等价字符串二、并查集总结参考文献前言 并查集有什么用?并查集是什么?搞懂这两个问题,相关的并查集问题就变得非常easy! 一、按字典序排列的最小的等价字符串 二、并查集 有一种方法&#x…

并查集

  • 前言
  • 一、按字典序排列的最小的等价字符串
  • 二、并查集
  • 总结
  • 参考文献

前言

并查集有什么用?并查集是什么?搞懂这两个问题,相关的并查集问题就变得非常easy!

一、按字典序排列的最小的等价字符串

在这里插入图片描述

二、并查集

有一种方法,并查集,它能将有关系的东西归为一类。
这里的问题,根据两字符的等价关系,将其归为一类,并得到最小字典序的root字符。
这里是一样的,只是选择每类的root字符时,需要比较一下,取字典序最小的字符节点作为root。

idea)构建好并查集后,遍历字符串baseStr,通过并查集寻找该字符的root,即该类最小等价字符。
注:
并查集是什么?并查集 = 数组 + union操作,经典的 数据结构 + 算法 == 程序,数组中每个元素为一个节点,根据节点的关系进行union操作,将各个节点分类。

func smallestEquivalentString(s1 string, s2 string, baseStr string) string {// 初始化并查集数据结构father := make([]byte,26)for i := 0;i < 26;i++ {father[i] = byte(i) // 这样方便改造树结构,且统一代码。i == father[i],此时返回father[i]和i的效果是一样的。}// 根据关系,做并查集操作unionfor i := 0;i < len(s1);i++ {union(s1[i],s2[i],father)}// 遍历baseStr,通过father数据结构的数据情况,来查找root字符rs := make([]byte,len(baseStr))for i := 0;i < len(baseStr);i++ {rs[i] = findRoot(baseStr[i],father)}return *(*string)(unsafe.Pointer(&rs))
}
func union(c1,c2 byte,father []byte) {cr1 := findFather(c1 - 97,father)cr2 := findFather(c2 - 97,father)if cr1 != cr2 {if cr1 < cr2 {father[cr2] = cr1}else {father[cr1] = cr2}}
}
func findFather(c byte,father []byte) byte {// 寻rootif father[c] != c {father[c] = findFather(father[c],father)}return father[c]
}
func findRoot(ch byte,father []byte) byte {ch = ch - 97for ; father[ch] != ch; {ch = father[ch]}return ch + 97
}

总结

1)并查集是什么?程序 = 数据结构+算法,并查集程序 = 数组 + union联合两节点。
2)并查集有什么用?每个数组元素为一个节点,根据节点关系union两节点,所以并查集的作用就是将元素归类。
3)并查集就像树一样,但是不是用链表来实现父子节点,而是连续内存的数组来实现。这跟字典树用arraylist来实现类似,并查集是子节点存父节点在数组中的位置,字典树是父节点存各个子节点在数组中的位置。毕竟并查集是从子找父,而字典树是从父找子。

参考文献

[1] LeetCode 按字典序排列的最小等价字符串

http://www.yayakq.cn/news/212545/

相关文章:

  • 东莞58同城做网站电话注册网站域名多少钱一年
  • 西安网站推广公司电话银川森林半岛
  • 佛山微网站建设天博徐州设计公司有哪些
  • 视频网站点击链接怎么做的上海人才网最新招聘信息
  • 手机网站的优势郑州网站关键词优化公司哪家好
  • 南宁网站建设培训学校ps怎么设计网页
  • 网站营销建设专业3合1网站建设价格
  • 深圳做网站乐云seo598在线传媒有限公司
  • 贵州省住房和城乡建设厅官网站首页万网一个ip建立多个网站
  • 阿里云虚拟主机多个网站集团网页建设
  • 南京做企业号微网站营销宿州注册公司多少钱
  • 房地产网站怎么推广微信24小时人工申诉
  • 龙岗网络营销网站制作哪里好各大网站网址是多少
  • 中国建设银行网站太慢了北京制作网站报价
  • 南昌网站建设利润免费全自动网页制作系统
  • 建设装修网站交互式网站开发
  • 国外经典手机网站设计app开发费用明细
  • 深南花园裙楼 网站建设手机网站的建设价格
  • 商城网站设计企业数字资产币币交易所网站开发
  • 电脑网站视频怎么下载营销型网站手机端
  • 重庆网站设计定制东莞市品牌网站建设价格
  • app官网入口整站关键词排名优化
  • 网站建设中怎么编辑图片网站营销方式
  • 自己动手创建一个公司网站个人简历封面
  • 网站界面分类网站建设一条龙
  • 网站开发seo要求用户体验设计方法
  • 网站开发从零到上线贵州软件制作
  • 重庆网站建设公司哪个最好注册网站平台
  • 深圳网站建设服务平台重庆綦江网站制作公司电话
  • 网站做seo创业 做网站