第十一章:图论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:

相关推荐
Aurora_th1 小时前
树与图的深度优先遍历(dfs的图论中的应用)
c++·算法·深度优先·图论·dfs·树的直径
夏天天天天天天天#6 小时前
求Huffman树及其matlab程序详解
算法·matlab·图论
浅念同学9 小时前
算法.图论-建图/拓扑排序及其拓展
算法·图论
Greyplayground12 小时前
【算法基础实验】图论-BellmanFord最短路径
算法·图论·最短路径
逝去的秋风13 小时前
【代码随想录训练营第42期 Day61打卡 - 图论Part11 - Floyd 算法与A * 算法
算法·图论·floyd 算法·a -star算法
浅念同学14 小时前
算法.图论-并查集上
java·算法·图论
蠢蠢的打码1 天前
8584 循环队列的基本操作
数据结构·c++·算法·链表·图论
逝去的秋风3 天前
【代码随想录训练营第42期 Day57打卡 - 图论Part7 - Prim算法与Kruskal算法
算法·图论·prim算法
热爱编程的OP4 天前
图论篇--代码随想录算法训练营第六十一天打卡| Floyd 算法,A*算法
数据结构·c++·学习·算法·图论
Aurora_th4 天前
图论三元环(并查集的高级应用)
c++·算法·图论·并查集·观察力·三元环