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

相关推荐
悠仁さん2 天前
数据结构 图(代码实现篇 C语言版)
数据结构·算法·图论
江屿风2 天前
C++图论基础Bellman-Ford与spfa算法如何判断负环
开发语言·c++·笔记·算法·图论
papership3 天前
【入门级-算法-8、图论算法:泛洪算法 (Flood Fill)】
算法·图论
江屿风3 天前
C++图论基础单源最短路-常规版dijkstra算法/堆优化版dijkstra算法/bellman-ford 算法/spfa 算法流食般投喂
开发语言·c++·笔记·算法·图论
hai3152475434 天前
一种通过空间几何转换进行软件编程计算的方式与现有计算的对比
人工智能·深度学习·数学建模·硬件架构·几何学·图论·拓扑学
江屿风5 天前
C++图论基础拓扑排序经典OJ题流食般投喂
开发语言·c++·笔记·算法·图论
Lsk_Smion6 天前
力扣实训 _ [207].课程表/图论
数据结构·leetcode·图论
江屿风9 天前
C++图论基础最小生成树经典OJ题流食般投喂
开发语言·c++·笔记·算法·深度优先·图论
San813_LDD10 天前
[数据结构]LeetCode学习
数据结构·算法·图论
handler0111 天前
【算法】并查集(普通/扩展/带权)模板与例题
数据结构·c++·笔记·算法·c·图论·查并集