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

edgesi.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;
    }
}
相关推荐
noipp3 小时前
推荐题目:洛谷 P10907 [蓝桥杯 2024 国 B] 蚂蚁开会
c语言·c++·算法·编程·洛谷
程序员二叉4 小时前
【JUC】线程池全套深度详解|参数|流程|拒绝策略|调优|异常处理
java·开发语言·jvm·算法·面试·juc
青山木4 小时前
Hot 100 --- 轮转数组
java·数据结构·算法
徐小夕4 小时前
Loop Engineering 深度解析与实战指南(全网最全)
前端·算法·github
北域码匠5 小时前
SHA-1算法:安全哈希原理与应用解析
算法·c#·哈希算法
手写码匠6 小时前
手写 GraphRAG:从零实现图增强检索增强生成系统
人工智能·深度学习·算法·aigc
BomanGe16 小时前
NSK重载高刚性滚珠丝杠技术详解
经验分享·算法·规格说明书
Matrix_117 小时前
手机里的计算摄影:广角形变校正算法
人工智能·算法·智能手机·计算摄影
WBluuue7 小时前
数据结构与算法:有序表(二):跳表
数据结构·c++·算法·skiplist
x138702859578 小时前
c语言中srtlen(指针使用计算字符长度)、传值和传址调用
c语言·开发语言·算法·visual studio