数据结构-并查集之按秩合并

class UnionFind:
    def __init__(self, size):
        # 每个节点的父节点
        self.parent = list(range(size))
        # 节点的秩
        self.rank = [0] * size
    
    # 查找父亲
    def find(self, x):
        # if x != self.parent[x]:
        #     # 路径压缩
        #     self.parent[x] = self.find(self.parent[x])
        # return self.parent[x]
        while x != self.parent[x]:
            x = self.parent[x]
        return x
    
    # 合并
    def union(self, x, y):
        rootX = self.find(x)
        rootY = self.find(y)
        if rootX != rootY:
            # 按秩合并
            if self.rank[rootX] > self.rank[rootY]:
                self.parent[rootY] = rootX
            elif self.rank[rootX] < self.rank[rootY]:
                self.parent[rootX] = rootY
            else:
                self.parent[rootY] = rootX
                self.rank[rootX] += 1
 
# 使用示例
uf = UnionFind(10)  # 假设有10个元素
uf.union(1, 2)
uf.union(2, 3)
uf.union(4, 5)
uf.union(6, 7)
uf.union(1, 4)  # 此时1,2,3,4,5属于同一个集合, 6,7一个集合
print(uf.find(1) == uf.find(5))  # 输出True, 因为1和5在同一个集合内

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

好无聊啊,烦死

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值