leetcod 685. 冗余连接 II

久违的没做太出来的题目,leetcod 685. 冗余连接 II

题目

在本问题中,有根树指满足以下条件的 有向 图。该树只有一个根节点,所有其他节点都是该根节点的后继。该树除了根节点之外的每一个节点都有且只有一个父节点,而根节点没有父节点。

输入一个有向图,该图由一个有着 n 个节点(节点值不重复,从 1 到 n)的树及一条附加的有向边构成。附加的边包含在 1 到 n 中的两个不同顶点间,这条附加的边不属于树中已存在的边。

结果图是一个以边组成的二维数组 edges 。 每个元素是一对 [ui, vi],用以表示 有向 图中连接顶点 ui 和顶点 vi 的边,其中 ui 是 vi 的一个父节点。

返回一条能删除的边,使得剩下的图是有 n 个节点的有根树。若有多个答案,返回最后出现在给定二维数组的答案。

示例 1:

输入:edges = [[1,2],[1,3],[2,3]]

输出:[2,3]

示例 2:

输入:edges = [[1,2],[2,3],[3,4],[4,1],[1,5]]

输出:[4,1]

提示:

n == edges.length

3 <= n <= 1000

edges[i].length == 2

1 <= ui, vi <= n

思路

本来还想直接像684一样直接并查集查到属于同一个祖先下的就返回直接ac了。没想到给我上了一课。事实上,这道题一共分三种情况讨论:


题解

复制代码
class Solution {
    int[] p;
    int n;
    public int[] findRedundantDirectedConnection(int[][] edges) {
        n = edges.length;
        int[] inDegree = new int[n+1];
        int node = -1;
        // 记录有没有入度为2的节点
        for (int i=0;i<n;i++) {
            if (++inDegree[edges[i][1]] > 1) {node = edges[i][1];}
        }
        // 如果有入度为2的节点,就倒着找这个入度为2的节点的入度连接去删除,看看是不是一个树
        if (node > -1) {
            for (int i=n-1;i>=0;i--) {
                if (edges[i][1] == node) {
                    if (check(edges, edges[i])) {return edges[i];}
                }
            }
        }
        // 如果没有入度为2的树那就是图里有环了,删除最后一个出现的就可以破坏环
        p = new int[n+1];
        for (int i=1;i<=n;i++) {p[i] = i;}
        for (int i=0;i<n;i++) {
            int a = edges[i][0], b = edges[i][1];
            int pa = find(a), pb = find(b);
            if (pa != pb) {p[pa] = pb;}
            else {return edges[i];}
        }
        return null;
    }
    public int find(int x) {
        if (p[x] != x) {p[x] = find(p[x]);}
        return p[x];
    }
    public boolean check(int[][] edges, int[] edge) {
        p = new int[n+1];
        for (int i=1;i<=n;i++) {p[i] = i;}
        for (int i=0;i<n;i++) {
            if (Arrays.equals(edge, edges[i])) {continue;}
            int a = edges[i][0], b = edges[i][1];
            int pa = find(a), pb = find(b);
            if (pa != pb) {p[pa] = pb;}
            else {return false;}
        }
        return true;
    }
}
相关推荐
凌肖战19 分钟前
力扣网编程55题:跳跃游戏之逆向思维
算法·leetcode
黑听人31 分钟前
【力扣 简单 C】70. 爬楼梯
c语言·leetcode
88号技师1 小时前
2025年6月一区-田忌赛马优化算法Tianji’s horse racing optimization-附Matlab免费代码
开发语言·算法·matlab·优化算法
ゞ 正在缓冲99%…2 小时前
leetcode918.环形子数组的最大和
数据结构·算法·leetcode·动态规划
Kaltistss2 小时前
98.验证二叉搜索树
算法·leetcode·职场和发展
知己如祭3 小时前
图论基础(DFS、BFS、拓扑排序)
算法
mit6.8243 小时前
[Cyclone] 哈希算法 | SIMD优化哈希计算 | 大数运算 (Int类)
算法·哈希算法
c++bug3 小时前
动态规划VS记忆化搜索(2)
算法·动态规划
哪 吒3 小时前
2025B卷 - 华为OD机试七日集训第5期 - 按算法分类,由易到难,循序渐进,玩转OD(Python/JS/C/C++)
python·算法·华为od·华为od机试·2025b卷
军训猫猫头3 小时前
1.如何对多个控件进行高效的绑定 C#例子 WPF例子
开发语言·算法·c#·.net