算法笔记(一)

并查集问题
在这里插入图片描述
互相连通的节点组成一个连通分量 如上图就是{0,1,2,5,6,7}{3,4,8,9}
quick_find
在这里插入图片描述
查询是否连通: 看对应的id是否一样
连接:将所有与给定对象之一的相同ID对应的项改成一样的,实现合并操作,但会造成很多值需要改变
直接代码实现:
在这里插入图片描述
访问数组的此时
查找:o(n)
合并:哦(n^2)
太慢了,改进一下
Quick-union
在这里插入图片描述
根节点相同则在一个连通分量里。
合并时非常简单,令第一个元素的根节点链接到第二个元素的根节点上在这里插入图片描述
在这里插入图片描述
代码实现:在这里插入图片描述
合并:
都不支持巨大连通图,再改进一下
在实现快速合并算法的时候执行一些操作避免得到很高的树
方法:把相对小的树的根节点 变成 相对大的树的根节点的子节点 带权
代码实现:
在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值