算法训练营day69

查并集:107. 寻找存在的路径 (kamacoder.com)

复制代码
#include<iostream>
#include<vector>

using namespace std;

vector<int> father(101, 0);

void init() {
    for(int i = 1;i <= 101;i++) {
        father[i] = i;
    }
}

int find(int v) {
    if(v == father[v]) return v;
    else return father[v] = find(father[v]);
}

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

bool isSame(int u, int v) {
    u = find(u);
    v = find(v);
    if(u == v) return true;
    else return false;
}

int main() {
    int N, M;
    cin >> N >> M;
    init();
    while(M--) {
        int i, j;
        cin >> i >> j;
        join(i, j);
    }
    int start, end;
    cin >> start >> end;
    if(isSame(start, end)) cout << 1 << endl;
    else cout << 0 << endl;
    return 0;
}
相关推荐
John.Lewis22 分钟前
C++初阶(14)list
开发语言·c++·笔记
hsjkdhs1 小时前
C++文件操作
开发语言·c++
沐怡旸2 小时前
【穿越Effective C++】条款4:确定对象使用前已先被初始化——C++资源管理的基石
c++·面试
淀粉肠kk2 小时前
【C++】多态
c++
ceclar1232 小时前
C++Lambda表达式
开发语言·c++·算法
bkspiderx2 小时前
Linux网络与路由配置完全指南
linux·运维·网络·c++
慧都小妮子3 小时前
基于C++ UA Server SDK开发高性能与跨平台 OPC UA 服务器
c++·跨平台·高性能·opc ua·ua server sdk
INGNIGHT3 小时前
单词搜索 II · Word Search II
数据结构·c++·算法
楼田莉子3 小时前
C++学习:C++11关于类型的处理
开发语言·c++·后端·学习
彷徨而立4 小时前
【C/C++】只知道窗口句柄,如何擦除窗口内容,清理窗口?
c语言·c++·windows