第十一章:图论part06 108.冗余连接 109.冗余连接II (补)

任务日期:7.31

题目一链接: 108. 冗余连接 (kamacoder.com)

思路:从前到后遍历边,如果当前两个点不在一个集合就使他们加入到一个集合,构成树,如果位于一个集合则输出他们,因为如果把他们加入就会形成环

代码:

cpp 复制代码
#include <bits/stdc++.h> 
using namespace std;
std::vector<int> father(1010,0);//按照节点大小范围定义数组
int n;

void unit() {
    for(int i = 0;i < n;i ++) {
        father[i] = i;
    }
}

int find(int u) {//寻找u的根节点
    return u == father[u] ? u : find(father[u]);//压缩距离:递归到下一层
}

void joint(int u,int v) {
    u = find(u);//这样节约空间不用重新定义新变量
    v = find(v);
    if(u == v) return;
    else father[v] = u;
}

bool issame(int u,int v) {
    u = find(u);
    v = find(v);
    return u == v;//bool函数可以返回true或者false
}

int main() {
    cin>>n;
    unit();
    for(int i = 0;i < n;i ++) {
        int s,t;
        cin>>s>>t;
        if(issame(s,t)) {//如果两个节点在一个集合
            cout<<s<<" "<<t;
            return 0;//从前往后找第一组符合条件的数据就是答案
        }
        else joint(s,t);//不在一个集合那么就使加入到一个集合以组成树
    }
}

难点:

解释细节1:




题目二链接:

思路:

代码:

难点:

解释细节1:




题目三链接:

思路:

代码:

难点:

解释细节1:

相关推荐
ValhallaCoder7 小时前
Day50-图论
数据结构·python·算法·图论
ValhallaCoder8 小时前
Day49-图论
数据结构·python·算法·图论
wuqingshun3141598 小时前
蓝桥杯 云神的子数组和
算法·蓝桥杯·图论
小魏每天都学习8 小时前
【数据结构学习】
算法·图论
zc.ovo1 天前
线段树优化建图
数据结构·c++·算法·图论
long3162 天前
弗洛伊德·沃肖算法 Floyd Warshall Algorithm
java·后端·算法·spring·springboot·图论
我是小疯子662 天前
C++图论:从基础到实战应用
java·c++·图论
罗湖老棍子3 天前
【例4-11】最短网络(agrinet)(信息学奥赛一本通- P1350)
算法·图论·kruskal·prim
Snow_day.3 天前
有关平衡树
数据结构·算法·贪心算法·动态规划·图论
qq_433554543 天前
C++ 图论算法:强连通分量
c++·算法·图论