代码随想录算法训练营第五十六天 | 图论part06

108. 冗余连接

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

using namespace std;

void init(vector<int> &father) {
    for (int i = 0; i < father.size(); ++i) {
        father[i] = i;
    }
}

int find(vector<int>& father, int u) {
    if (father[u] == u) return u;
    return father[u] = find(father, father[u]);
}

int isSame(vector<int>& father, int u, int v) {
    u = find(father, u);
    v = find(father, v);
    return u == v;
}

void join(vector<int>& father, int u, int v) {
    u = find(father, u);
    v = find(father, v);
    if (u == v) return;
    father[v] = u;
}
int main()
{
    int n, u, v, resultu, resultv;
    cin >> n;
    vector<int> father(n + 1, 0);
    init(father);
    for (int i = 0; i < n; ++i) {
        cin >> u >> v;
        if (isSame(father, u, v)) {
            resultu = u;
            resultv = v;
        }
        else
            join(father, u, v);
    }
    cout << resultu << " " << resultv << endl;
    return 0;
}

109. 冗余连接II

关键是要能够分出两种情况:

  1. 是不是存在入度为2的点,然后判断哪一条边去掉,还是连通的。在这里也有两种情况,一种是直接删除最后一个边,一种是会形成环。
  2. 是不是存在环
cpp 复制代码
#include <iostream>
#include <vector>

using namespace std;

void init(vector<int>& father) {
    for (int i = 0; i < father.size(); ++i) {
        father[i] = i;
    }
}

int find(vector<int>& father, int u) {
    if (father[u] == u) return u;
    return father[u] = find(father, father[u]);
}

int isSame(vector<int>& father, int u, int v) {
    u = find(father, u);
    v = find(father, v);
    return u == v;
}

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

bool isTreeAfterRemove(vector<int>& father, const vector<vector<int>>& edges, int deleteEdge) {
    init(father);
    for (int i = 0; i < edges.size(); ++i) {
        if (i == deleteEdge) continue;
        if (isSame(father, edges[i][0], edges[i][1]))
            return false;
        join(father, edges[i][0], edges[i][1]);
    }
    return true;
}

void getRemoveEdge(vector<int>& father, const vector<vector<int>>& edges) {
    init(father);
    for (vector<int> pair : edges) {
        if (isSame(father, pair[0], pair[1])) {
            cout << pair[0] << " " << pair[1] << endl;
            return;
        }
        join(father, pair[0], pair[1]);
    }
}

int main()
{
    int n, u, v;
    cin >> n;
    vector<int> father(n + 1, 0);
    vector<vector<int>> edges;
    vector<int> inDegrees(n + 1, 0);
    for (int i = 0; i < n; ++i) {
        cin >> u >> v;
        inDegrees[v]++;
        edges.emplace_back(vector<int>{u, v});
    }

    vector<int> vec;
    for (int i = n - 1; i >= 0; --i) {
        if (inDegrees[edges[i][1]] == 2)
            vec.push_back(i);
    }
    if (vec.size() > 0) {
        if (isTreeAfterRemove(father, edges, vec[0])) {
            cout << edges[vec[0]][0] << " " << edges[vec[0]][1] << endl;
        }
        else
            cout << edges[vec[1]][0] << " " << edges[vec[1]][1] << endl;
        return 0;
    }
    getRemoveEdge(father, edges);
    return 0;
}
相关推荐
不会就选b17 小时前
算法日常・每日刷题--<二分查找>1
算法
「維他檸檬茶」18 小时前
大模型算法学习2026.6.13
学习·算法
叫我:松哥18 小时前
基于Python的共享单车租赁数据分析与预测系统,技术栈flask+boostrap+随机森林+XGBoost
人工智能·python·深度学习·算法·随机森林·数据分析·flask
BAGAE18 小时前
星链卫星数据获取:从太空安全到实时通信的技术革命
网络·数据结构·数据库·算法·云计算·hbase
happymaker062618 小时前
LeetCodeHor100——438.找到字符串中所有的字母异位词
算法
西安邮电大学18 小时前
有关栈的经典算法题
java·后端·其他·算法·面试
h_a_o777oah18 小时前
【算法专项】扩展域并查集:原理详解及解决大部分种类并查集问题(洛谷P5937 P2024 C++代码)
数据结构·c++·算法·acm·并查集·扩展域·逻辑建模
兰令水19 小时前
leecodecode【单调栈】【2026.6.12打卡-java版本】
java·开发语言·算法
TMT星球19 小时前
魔法原子上交会首秀VLA K02大模型,完成具身智能从“执行”到“理解”的能力跃迁
人工智能·算法·机器学习
2301_7644413319 小时前
番茄钟+AI:高效专注的秘密武器
人工智能·算法·数学建模·动态规划·交互