news 2026/4/15 8:06:26

冗余连接II

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
冗余连接II

本文参考代码随想录

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

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

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

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

思路

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

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

classSolution:definit(self,n):self.fathers=[iforiinrange(n+1)]deffind(self,u):ifself.fathers[u]==u:returnu self.fathers[u]=self.find(self.fathers[u])returnself.fathers[u]defisSame(self,u,v):returnself.find(u)==self.find(v)defjoin(self,u,v):# u -> vu=self.find(u)v=self.find(v)ifu==v:returnself.fathers[v]=udefisTreeAfterRemove(self,edge,edges):self.init(len(edges)+1)foreinedges:ife==edge:continueifself.isSame(e[0],e[1]):returnFalseself.join(e[0],e[1])returnTruedefremoveCircleEdge(self,edges):self.init(len(edges)+1)foreinedges:ifself.isSame(e[0],e[1]):returne self.join(e[0],e[1])deffindRedundantDirectedConnection(self,edges:List[List[int]])->List[int]:inDegrees=[0]*(len(edges)+1)twoDegreeVecs=[]foreinedges:inDegrees[e[1]]+=1foreinedges:ifinDegrees[e[1]]==2:twoDegreeVecs.append(e)iflen(twoDegreeVecs)>0:foreintwoDegreeVecs[::-1]:ifself.isTreeAfterRemove(e,edges):returnereturnself.removeCircleEdge(edges)
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/10 19:11:08

Winhance v26.01.12 便携版:Windows 系统优化工具

Winhance v26.01.12 便携版是专为 Win10/Win11 打造的专业 Windows 系统优化工具,无需重装系统就能解决电脑卡顿、系统冗余等问题,帮助用户实现系统瘦身与性能提升,让新旧电脑都能拥有流畅运行体验,是 Windows 系统优化领域的实用…

作者头像 李华
网站建设 2026/4/10 13:03:51

STM32中I2C重入问题与中断处理图解说明

STM32中I2C重入问题与中断处理实战解析一个传感器读取失败的“灵异事件”你有没有遇到过这样的情况:系统运行几分钟都正常,突然一次温湿度数据跳变成0?或者日志里某个时间戳写进了错误的值?调试时用逻辑分析仪一抓——发现I2C总线…

作者头像 李华
网站建设 2026/4/10 5:26:07

基于STM32H7的串口不定长接收图解说明

一文搞懂STM32H7串口不定长接收:DMA 空闲中断的实战精髓 你有没有遇到过这样的场景? 设备通过串口发来一帧长度不固定的数据——可能是10字节的传感器采样,也可能是上百字节的配置命令。你用传统轮询方式处理,CPU占用飙到80%&am…

作者头像 李华
网站建设 2026/4/12 10:13:06

log_softmax和sigmoid防止溢出原理

1sum_softmax推理指数函数的输出永远最大只有 1,前面常量不涉及指数计算基本不会溢出。2 sigmoid的安全处理对于常见操作# 极易下溢出!如果 logits 很小,pred 变成 0,log(0) 报错 pred torch.sigmoid(logits) loss torch.nn.BCE…

作者头像 李华
网站建设 2026/4/12 10:36:41

Python 基础入门完全指南

Python 作为一门解释型、面向对象、动态数据类型的高级程序设计语言,凭借简洁的语法、丰富的库生态和极低的入门门槛,成为了编程新手的首选语言。无论是数据分析、人工智能、Web 开发还是自动化脚本编写,Python 都能胜任。本文将从零基础视角…

作者头像 李华