冗余连接II

本文参考代码随想录

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

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

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

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

思路

有如下三种情况,前两种情况是出现入度为2的点,

第三种情况是没有入度为2的点,那么图中一定出现了有向环

python 复制代码
class Solution:
    def init(self, n):
        self.fathers = [i for i in range(n + 1)]
    def find(self, u):
        if self.fathers[u] == u:
            return u
        self.fathers[u] = self.find(self.fathers[u])
        return self.fathers[u]
    def isSame(self, u, v):
        return self.find(u) == self.find(v)

    def join(self, u, v):
        # u -> v
        u = self.find(u)
        v = self.find(v)
        if u == v:
            return
        self.fathers[v] = u

    def isTreeAfterRemove(self, edge, edges):
        self.init(len(edges) + 1)
        for e in edges:
            if e == edge:
                continue
            if self.isSame(e[0], e[1]):
                return False
            self.join(e[0], e[1])
        return True
    
    def removeCircleEdge(self, edges):
        self.init(len(edges) + 1)
        for e in edges:
            if self.isSame(e[0], e[1]):
                return e
            self.join(e[0], e[1])

    def findRedundantDirectedConnection(self, edges: List[List[int]]) -> List[int]:
        inDegrees = [0] * (len(edges) + 1)
        twoDegreeVecs = []
        for e in edges:
            inDegrees[e[1]] += 1
        for e in edges:
            if inDegrees[e[1]] == 2:
                twoDegreeVecs.append(e)
        if len(twoDegreeVecs) > 0:
            for e in twoDegreeVecs[::-1]:
                if self.isTreeAfterRemove(e, edges):
                    return e
        return self.removeCircleEdge(edges)
相关推荐
数研小生6 小时前
构建命令行单词记忆工具:JSON 词库与艾宾浩斯复习算法的完美结合
算法·json
芒克芒克6 小时前
LeetCode 题解:除自身以外数组的乘积
算法·leetcode
Python 老手6 小时前
Python while 循环 极简核心讲解
java·python·算法
@Aurora.6 小时前
优选算法【专题九:哈希表】
算法·哈希算法·散列表
爱看科技7 小时前
微美全息(NASDAQ:WIMI)研究拜占庭容错联邦学习算法,数据安全与隐私保护的双重保障
算法
qq_417129257 小时前
C++中的桥接模式变体
开发语言·c++·算法
YuTaoShao8 小时前
【LeetCode 每日一题】3010. 将数组分成最小总代价的子数组 I——(解法二)排序
算法·leetcode·排序算法
吴维炜9 小时前
「Python算法」计费引擎系统SKILL.md
python·算法·agent·skill.md·vb coding
Σίσυφος190010 小时前
PCL Point-to-Point ICP详解
人工智能·算法
玄〤10 小时前
Java 大数据量输入输出优化方案详解:从 Scanner 到手写快读(含漫画解析)
java·开发语言·笔记·算法