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;
    }
}
相关推荐
KaMeidebaby20 小时前
卡梅德生物技术快报|酵母双杂交 cDNA 文库构建与蛋白互作筛选流程
服务器·前端·数据库·人工智能·算法
圣保罗的大教堂20 小时前
leetcode 3300. 替换为数位和以后的最小元素 简单
leetcode
sheeta199820 小时前
LeetCode 每日一题笔记 日期:2026.05.27 题目:3121. 统计特殊字母的数量 II
笔记·算法·leetcode
ST——Jess21 小时前
年度行业趋势研究报告:泛心理数字化赛道“流日推演”的算法困境与高保真交互范式重构
人工智能·算法·架构
Tisfy21 小时前
LeetCode 3300.替换为数位和以后的最小元素:一次遍历
数学·算法·leetcode·模拟
garmin Chen21 小时前
LeetcodeHot100打卡(14、合并空间,15、轮转数组,16、除了自身以外数组乘积,17.缺失的第一个整数)
java·笔记·学习·算法
elseif12321 小时前
【C++】vector 详细版
开发语言·c++·算法
变量未定义~21 小时前
既约分数、阶乘约数、逆元、最大质因子个数【算法赛】
算法
KaMeidebaby1 天前
卡梅德生物技术快报|Western Blot 实验应用:肺肠轴机制研究全流程技术解析
前端·数据库·人工智能·算法·百度