代码随想录算法训练营Day59

并查集理论基础

力扣1971.寻找图中是否存在路径【easy】

一、并查集理论基础

文档链接:代码随想录

1、并查集

作用
  • 将两个元素添加到一个集合中。
  • 判断两个元素在不在同一个集合
路径压缩
  • 如果这棵多叉树高度很深的话,每次find函数 去寻找根的过程就要递归很多次。
  • 我们的目的只需要知道这些节点在同一个根下就可以,所以对这棵多叉树的构造只需要这样就可以了,如图:
按秩合并
  • 目标:合并两个集合的根节点。
  • 总是将小树(高度低)合并到大树(高度高)的根下,避免树的高度过高。

2、代码

  • find:压缩路径
python 复制代码
def find(self, x):
    if self.parent[x] != x:
        self.parent[x] = self.find(self.parent[x])  # 递归找根,并更新父节点
    return self.parent[x]
  • union:秩合并
python 复制代码
  def union(self, x, y):
        root_x = self.find(x)
        root_y = self.find(y)
        if root_x == root_y:
            return  # 已在同一集合
        # 按秩合并:小树合并到大树
        if self.rank[root_x] < self.rank[root_y]:
            self.parent[root_x] = root_y
        else:
            self.parent[root_y] = root_x
            if self.rank[root_x] == self.rank[root_y]:
                self.rank[root_x] += 1  # 树高度+1

二、力扣1971.寻找图中是否存在路径【easy】

题目链接:力扣1971.寻找图中是否存在路径

视频链接:代码随想录

题解链接:力扣

1、思路

  • 时间复杂度: O ( n + m ) O(n + m) O(n+m)

2、代码

  • 并查集
python 复制代码
class Solution:
    def validPath(self, n: int, edges: List[List[int]], source: int, destination: int) -> bool:
        def find(x):
            if p[x] != x:
                p[x] = find(p[x])
            return p[x]
        p = list(range(n))
        for u, v in edges:
            p[find(u)] = find(v)
        return find(source) == find(destination)
  • dfs
python 复制代码
class Solution:
    def validPath(self, n: int, edges: List[List[int]], source: int, destination: int) -> bool:
        def dfs(i):
            if i == destination:
                return True
            vis.add(i)
            for j in g[i]:
                if j not in vis and dfs(j):
                    return True
            return False
        g = defaultdict(list)
        for a, b in edges:
            g[a].append(b)
            g[b].append(a)
        vis = set()
        return dfs(source)
                

相关推荐
徐行tag31 分钟前
深度学习基础——神经网络优化算法
深度学习·神经网络·算法
liuzhangfeiabc3 小时前
[luogu12541] [APIO2025] Hack! - 交互 - 构造 - 数论 - BSGS
c++·算法·题解
平和男人杨争争5 小时前
山东大学计算机图形学期末复习15——CG15
人工智能·算法·计算机视觉·图形渲染
爱coding的橙子6 小时前
每日算法刷题Day11 5.20:leetcode不定长滑动窗口求最长/最大6道题,结束不定长滑动窗口求最长/最大,用时1h20min
算法·leetcode·职场和发展
WenGyyyL6 小时前
力扣热题——零数组变换 |
算法·leetcode·职场和发展·蓝桥杯
芯眼6 小时前
AMD Vivado™ 设计套件生成加密比特流和加密密钥
算法·fpga开发·集成测试·软件工程
咪嗷喵挖藕哇6 小时前
leetcode 合并区间 java
java·算法·leetcode
沐风ya6 小时前
leetcode每日一题 -- 3355. 零数组变换 I
算法·leetcode
纪伊路上盛名在6 小时前
leetcode字符串篇【公共前缀】:14-最长公共前缀
python·算法·leetcode
JK0x076 小时前
代码随想录算法训练营 Day52 图论Ⅲ 岛屿问题Ⅱ 面积 孤岛 水流 造岛
算法·深度优先·图论