冗余连接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)
相关推荐
凌波粒11 分钟前
LeetCode--349.两个数组的交集(哈希表)
java·算法·leetcode·散列表
paeamecium1 小时前
【PAT甲级真题】- Student List for Course (25)
数据结构·c++·算法·list·pat考试
Book思议-2 小时前
【数据结构】栈与队列全方位对比 + C 语言完整实现
c语言·数据结构·算法··队列
SteveSenna2 小时前
项目:Trossen Arm MuJoCo
人工智能·学习·算法
NAGNIP2 小时前
一文搞懂CNN经典架构-DenseNet!
算法·面试
道法自然|~2 小时前
BugCTF黄道十二宫
算法·密码学
WHS-_-20223 小时前
Python 算法题学习笔记一
python·学习·算法
沉鱼.443 小时前
第六届题目
算法
黑眼圈子3 小时前
总结一下用Java做算法的常用类和方法
java·开发语言·算法
apcipot_rain3 小时前
天梯赛练习集 时间规划 限时复盘 中档题详解(L1-6~L2-4)
算法