代码随想录算法训练营第55天| 并查集 107.寻找存在的路径

并查集理论基础:

简单来说就是看一些点是否在同一个集合里。主要用来解决连通性问题。他有两个功能,一个是判断两个元素是否属于同一集合,另一个是将两个元素加入集合。重点在寻根过程,默认一个元素她的根是她自己,如果是的话,就返回她本身,如果不是的话就去找她的根的根。此外还有判断功能和合并功能。

第一次做还是有点不熟练,一遍看定义一边写,本身并不难。

107.寻找存在的路径

题目链接:107.寻找存在的路径

代码:

cpp 复制代码
//因为是否在一组 只需要判断father相不相同就可以 所以有向图无向图都可以用
#include<iostream>
using namespace std;
#include<vector>

vector<int> father;

//找到这个点的根 寻根过程
int find(int s){
    if(father[s]==s) return s;//如果根就是自己 直接返回
    else return find(father[s]);//如果不是 就层层寻找他的根的根
}

//将s,t这条边加入并查集
void join(int s, int t){
    s=find(s);
    t=find(t);//找到这个点的根
    if(s==t) return;
    father[t]=s;
}


bool issame(int s, int t){
    s=find(s);
    t=find(t);
    return s==t;
}

int main(){
    int m,n,s,t;
    cin>>n>>m;
    
    //存储点n的根是哪个点
    
    for(int i=0;i<=n;i++){
       father.push_back(i);
    }
    
    for(int i=0;i<m;i++){
        cin>>s>>t;
        join(s,t);
    }
    
    cin>>m>>n;
    if(issame(m,n))cout<<1;
    else cout<<0;
    return 0;
}
相关推荐
萌>__<新1 天前
力扣打卡每日一题——缺失的第一个正数
数据结构·算法·leetcode
DuHz1 天前
车对车对向交汇场景的毫米波路径损耗建模论文精读
论文阅读·算法·汽车·信息与通信·信号处理
lxh01131 天前
二叉树中的最大路径和
前端·算法·js
萌>__<新1 天前
力扣打卡每日一题————零钱兑换
算法·leetcode·职场和发展
重生之后端学习1 天前
238. 除自身以外数组的乘积
java·数据结构·算法·leetcode·职场和发展·哈希算法
yaoxin5211231 天前
269. Java Stream API - Map-Filter-Reduce算法模型
java·python·算法
Bruce_kaizy1 天前
C++树形数据结构————树状数组、线段树中“逆序对”的问题
开发语言·数据结构·c++
FMRbpm1 天前
用栈实现队列
数据结构·c++·新手入门
添砖java‘’1 天前
常见的进程间通信方式详解
linux·c++·操作系统·信息与通信·进程通信
AA陈超1 天前
LyraStarterGame_5.6 Experience系统加载流程详细实现
c++·笔记·学习·ue5·虚幻引擎·lyra