更弱智的算法学习 day56
使用并查集遍历所有边。当遇到一条边连接的两个节点已经属于同一连通分量时这条边就是冗余边因为它会形成环。由于代码按输入顺序遍历边最后记录的冗余边即为输入中最后出现的。遍历每条边时若s和t已连通is_same(s, t)为True说明添加该边会形成环因此记录为result。由于继续遍历后续边result会被更新最终保留的是最后一条导致环的边符合题目要求。若非冗余边则调用join(s, t)合并集合维护连通性。​输出​打印最后记录的冗余边。father list() def find(u): if u father[u]: return u else: father[u] find(father[u]) return father[u] def is_same(u, v): u find(u) v find(v) return u v def join(u, v): u find(u) v find(v) if u ! v: father[u] v if __name__ __main__: # 輸入 n int(input()) for i in range(n 1): father.append(i) # 尋找冗余邊 result None for i in range(n): s, t map(int, input().split()) if is_same(s, t): result str(s) str(t) else: join(s, t) # 輸出 print(result)from collections import defaultdict father list() def find(u): if u father[u]: return u else: father[u] find(father[u]) return father[u] def is_same(u, v): u find(u) v find(v) return u v def join(u, v): u find(u) v find(v) if u ! v: father[u] v def is_tree_after_remove_edge(edges, edge, n): # 初始化并查集 global father father [i for i in range(n 1)] for i in range(len(edges)): if i edge: continue s, t edges[i] if is_same(s, t): # 成環即不是有向樹 return False else: # 將s,t放入集合中 join(s, t) return True def get_remove_edge(edges): # 初始化并查集 global father father [i for i in range(n 1)] for s, t in edges: if is_same(s, t): print(s, t) return else: join(s, t) if __name__ __main__: # 輸入 n int(input()) edges list() in_degree defaultdict(int) for i in range(n): s, t map(int, input().split()) in_degree[t] 1 edges.append([s, t]) # 尋找入度為2的邊並紀錄其下標(index) vec list() for i in range(n - 1, -1, -1): if in_degree[edges[i][1]] 2: vec.append(i) # 輸出 if len(vec) 0: # 情況一刪除輸出順序靠後的邊 if is_tree_after_remove_edge(edges, vec[0], n): print(edges[vec[0]][0], edges[vec[0]][1]) # 情況二只能刪除特定的邊 else: print(edges[vec[1]][0], edges[vec[1]][1]) else: # 情況三 原圖有環 get_remove_edge(edges)

相关新闻

【软件测试】6_性能测试实战 _建立测试环境

【软件测试】6_性能测试实战 _建立测试环境

文章目录一、建立测试环境1.1 性能测试环境的特点1.2 如何保证测试环境与生产环境的一致性二、构造测试数据-慢查询使用2.1 good_insert.py一、建立测试环境 性能测试的环境独立使用 —— 其他测试人员不可用使用该环境 在进行性能则试之前,需要先完成性能测试环境…

2026/7/4 8:31:30 阅读更多 →
如何用CLAUDECODE重塑嵌入式开发

如何用CLAUDECODE重塑嵌入式开发

现在请你帮我创建两个SKILL,第一个SKILL是硬件原理图对比 专家:用来比对鲁班猫官方的原理图(INIT_LubanCat3_EBF41051 3V1R0_SCH_*.png)和我公司硬件人员画得原理图(CD0_RK3576_MA IN_V10_*.png)之间的差异,然后给出差…

2026/7/3 17:03:43 阅读更多 →
3.3 xue

3.3 xue

3.3 InSAR中的对流层与电离层校正及使用GACOS对流层校正 sarsarsar 相关参考文献: GACOS: • Yu, C., N. T. Penna, and Z. Li (2017), Generation of real-time mode high-resolution water vapor fields from GPS observations, J. Geophys. Res. Atmos., 122, 2008–20…

2026/7/3 17:03:42 阅读更多 →

最新新闻

THSTrader完全指南:5步配置雷电模拟器与同花顺APP实战教程

THSTrader完全指南:5步配置雷电模拟器与同花顺APP实战教程

THSTrader完全指南:5步配置雷电模拟器与同花顺APP实战教程 【免费下载链接】THSTrader 量化交易工具。同花顺手机版模拟炒股python API,基于uiautomator2和图色方法实现。【可自行扩展到实盘】 项目地址: https://gitcode.com/gh_mirrors/th/THSTrader…

2026/7/4 8:35:20 阅读更多 →
用AI变声神器RVC实现10分钟语音转换:从零开始的完整实战指南

用AI变声神器RVC实现10分钟语音转换:从零开始的完整实战指南

用AI变声神器RVC实现10分钟语音转换&#xff1a;从零开始的完整实战指南 【免费下载链接】Retrieval-based-Voice-Conversion-WebUI Easily train a good VC model with voice data < 10 mins! 项目地址: https://gitcode.com/GitHub_Trending/re/Retrieval-based-Voice-C…

2026/7/4 8:31:20 阅读更多 →
从“是什么“到“为什么“:现代系统诊断工具witr如何重新定义进程分析范式

从“是什么“到“为什么“:现代系统诊断工具witr如何重新定义进程分析范式

从"是什么"到"为什么"&#xff1a;现代系统诊断工具witr如何重新定义进程分析范式 【免费下载链接】witr Why is this running? 项目地址: https://gitcode.com/GitHub_Trending/wi/witr 在当今复杂的系统环境中&#xff0c;当进程异常消耗资源、端…

2026/7/4 8:29:19 阅读更多 →
如何用Flask-profiler定位最耗时的API端点?实战案例分享

如何用Flask-profiler定位最耗时的API端点?实战案例分享

如何用Flask-profiler定位最耗时的API端点&#xff1f;实战案例分享 【免费下载链接】flask-profiler a flask profiler which watches endpoint calls and tries to make some analysis. 项目地址: https://gitcode.com/gh_mirrors/fl/flask-profiler Flask-profiler是…

2026/7/4 8:29:19 阅读更多 →
FlipperZeroHondaFirmware工作原理深度解析:433MHz RF信号捕获技术

FlipperZeroHondaFirmware工作原理深度解析:433MHz RF信号捕获技术

FlipperZeroHondaFirmware工作原理深度解析&#xff1a;433MHz RF信号捕获技术 【免费下载链接】FlipperZeroHondaFirmware Custom Firmware for the Flipper Zero, to add support for Honda key fobs (FCC ID: KR5V2X) 项目地址: https://gitcode.com/gh_mirrors/fl/Flippe…

2026/7/4 8:23:17 阅读更多 →
大模型‘养虾测试’:评估世界模型与长程一致性新标尺

大模型‘养虾测试’:评估世界模型与长程一致性新标尺

1. 项目概述&#xff1a;当“养虾”成为大模型能力测试的新标尺最近在好几个技术群和行业论坛里&#xff0c;频繁看到有人甩出一句&#xff1a;“来&#xff0c;养只虾试试&#xff1f;”——不是水产养殖交流&#xff0c;也不是美食探店邀约&#xff0c;而是工程师、产品经理、…

2026/7/4 8:19:17 阅读更多 →

日新闻

Memcached 1.6.43 发布:关键安全修复版本,多项问题得到解决

Memcached 1.6.43 发布:关键安全修复版本,多项问题得到解决

Memcached 1.6.43 正式发布&#xff0c;这是一个关键的安全修复版本&#xff0c;修复了多个方面的问题&#xff0c;还对部分功能进行了优化。 安全修复亮点 此次发布在安全修复上表现突出。binprot 避免了项目引用计数溢出&#xff0c;mcmc 因安全问题提升了上游版本号&#xf…

2026/7/4 0:04:29 阅读更多 →
终极指南:使用HMCL启动器跨平台畅玩Minecraft的完整解决方案

终极指南:使用HMCL启动器跨平台畅玩Minecraft的完整解决方案

终极指南&#xff1a;使用HMCL启动器跨平台畅玩Minecraft的完整解决方案 【免费下载链接】HMCL A Minecraft Launcher which is multi-functional, cross-platform and popular 项目地址: https://gitcode.com/gh_mirrors/hm/HMCL HMCL&#xff08;Hello Minecraft! Lau…

2026/7/4 0:06:29 阅读更多 →
KMX63与PIC18F66K40在嵌入式HMI中的硬件协同与低功耗设计

KMX63与PIC18F66K40在嵌入式HMI中的硬件协同与低功耗设计

1. KMX63与PIC18F66K40的硬件协同架构解析KMX63作为一款三轴加速度计和磁力计组合传感器&#xff0c;与PIC18F66K40微控制器的搭配堪称嵌入式HMI开发的黄金组合。这套硬件组合的核心优势在于KMX63提供的高精度运动感知能力与PIC18F66K40强大的信号处理能力形成了完美互补。KMX6…

2026/7/4 0:06:29 阅读更多 →

周新闻

月新闻