代码随想录 107. 寻找存在的路径

107. 寻找存在的路径

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

int find(int u, vector<int>& father){
    return u == father[u] ? u : father[u] = find(father[u], father);
}

void join(int u, int v, vector<int>& father){
    u = find(u, father);
    v = find(v, father);
    if (u == v) return;
    father[v] = u;
}

int main(){
    int n, m;
    cin >> n >> m;
    vector<int> father(n);
    iota(father.begin(), father.end(), 0);
    for (int i = 0; i < m; i++){
        int u, v;
        cin >> u >> v;
        u--;
        v--;
        join(u, v, father);
    }
    int u, v;
    cin >> u >> v;
    u--;
    v--;
    if (find(u, father) == find(v, father)) cout << 1;
    else cout << 0;
    
    return 0;
}

要解这题可以将一个连通图看作是一个集合,只要判断两个元素是否属于同一集合就能够判断是否存在通路。普通的查找是已知集合的容器位置,在容器中寻找元素,就像是在书包中找前一晚的作业,翻完一遍前都不知道有没有忘带作业)。查并集则是根据元素来查找安放元素的地方,就像菜鸟驿站的取件码,一串取件码有柜号、层号、序列号,我们根据柜号就能知道两个快递是否在一个柜子上,层号同理。值得注意的时,在查并集创建修改的过程中,需要找到一个元素的根节点才能开始操作,这是为了保证节点构成的图是连通的,在以一维数组作为查并集时,一个节点的出度只有1,所以就要找到出度指向自己的根节点进行操作,否则构建的查并集就乱了。

代码随想录 107. 寻找存在的路径

相关推荐
坚持编程的菜鸟7 分钟前
LeetCode每日一题——螺旋矩阵
c语言·算法·leetcode·矩阵
汉克老师10 分钟前
GESP2025年9月认证C++四级( 第三部分编程题(1)排兵布阵)
c++·算法·gesp4级·gesp四级
(●—●)橘子……14 分钟前
记力扣2009:使数组连续的最少操作数 练习理解
数据结构·python·算法·leetcode
GalaxyPokemon17 分钟前
LeetCode - 1171.
算法·leetcode·链表
budingxiaomoli43 分钟前
算法---双指针一
算法
iナナ1 小时前
Java优选算法——位运算
java·数据结构·算法·leetcode
热爱生活的猴子1 小时前
算法279. 完全平方数
算法·深度优先
sali-tec1 小时前
C# 基于halcon的视觉工作流-章45-网格面划痕
开发语言·算法·计算机视觉·c#
通信小呆呆1 小时前
5G NR 信号检测:从 PSS 相关到 SSB 栅格恢复
算法·5g
Han.miracle2 小时前
数据结构二叉树——层序遍历&& 扩展二叉树的左视图
java·数据结构·算法·leetcode