Leetcode 刷题笔记 图论part05

卡码网 107 寻找存在的路径

初识并查集

并查集功能:

  1. 寻找根节点,函数: find(int u),也就是判断这个节点的祖先节点是哪个
  2. 将两个节点接入到同一个集合,函数: join(int u, int v),将两个节点连在同一个根节点上
  3. 判断两个节点是否在同一个集合,函数: isSame(int u, int v),就是判断两个节点是不是同一个根节点
python 复制代码
class UnionFind:
    def __init__(self, size):
        self.parent = list(range(size + 1))
    
    def find(self, u):
        if self.parent[u] != u:
            self.parent[u] = self.find(self.parent[u])
        return self.parent[u]
    def union(self, u, v):
        root_u = self.find(u)
        root_v = self.find(v)
        if root_u != root_v:
            self.parent[root_v] = root_u
    def is_same(self, u, v):
        return self.find(u) == self.find(v)

def main():
    import sys
    input = sys.stdin.read
    data = input().split()
    index = 0
    n = int(data[index])
    index += 1
    m = int(data[index])
    index += 1
    uf = UnionFind(n)
    for _ in range(m):
        s = int(data[index])
        index += 1
        t = int(data[index])
        index += 1
        uf.union(s, t)
    source = int(data[index])
    index += 1
    destination = int(data[index])
    if uf.is_same(source, destination):
        print(1)
    else:
        print(0)

if __name__ == '__main__':
    main()
相关推荐
因为奋斗超太帅啦几秒前
Git分布式版本控制工具学习笔记(一)——git本地仓库的基本使用
笔记·git·学习
可可苏饼干30 分钟前
LVS服务器
linux·运维·笔记·学习·lvs
四谎真好看37 分钟前
Java 黑马程序员学习笔记(进阶篇27)
java·开发语言·笔记·学习·学习笔记
报错小能手42 分钟前
C++笔记 仿函数(函数对象)
开发语言·c++·笔记
IT阳晨。1 小时前
【神经网络与深度学习(吴恩达)】深度学习概论学习笔记
笔记·深度学习·神经网络
做怪小疯子4 小时前
LeetCode 热题 100——子串——和为 K 的子数组
算法·leetcode·职场和发展
AA陈超7 小时前
ASC学习笔记0014:手动添加一个新的属性集
c++·笔记·学习·ue5
Chunyyyen7 小时前
【第二十二周】自然语言处理的学习笔记06
笔记·学习·自然语言处理
希望有朝一日能如愿以偿9 小时前
力扣每日一题:仅含1的子串数
算法·leetcode·职场和发展
苏小瀚10 小时前
算法---FloodFill算法和记忆化搜索算法
数据结构·算法·leetcode