news 2026/6/23 17:26:27

代码随想录算法训练营Day48 | 108.冗余连接、109.冗余连接II

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
代码随想录算法训练营Day48 | 108.冗余连接、109.冗余连接II

KamaCoder108.冗余连接

108. 多余的边

1.思路

对于边(s, t),使用find(s)find(t)分别查找st所在集合的根节点。

如果根节点相同:说明st本来就在同一个集合中,即它们已经连通。此时,边(s, t)的加入必定会形成环。这就是我们要找的第一条成环边,直接输出(s, t)并结束程序。

如果根节点不同:说明st尚未连通。此时,使用join(s, t)将它们所在的两个集合合并,表示它们现在连通了。然后继续处理下一条边。

#include <iostream> #include <vector> using namespace std; int n; vector<int>father(1005,1); void init(){ for(int i=1;i<=n;i++){ father[i]=i; } } int find(int u){ if(u==father[u]){ return u; } return father[u]=find(father[u]); } // 将v->u 这条边加入并查集 int join(int u,int v){ u=find(u); v=find(v); if(u==v) return 0; // 如果发现根相同,则说明在一个集合,不用两个节点相连直接返回 father[u]=v; return 1; } int main(){ cin>>n; init(); for(int i=0;i<n;i++){ int s,t;cin>>s>>t; if(!join(s,t)){ cout<<s<<" "<<t<<endl; break; } } return 0; }

2.思考

这道题只需要在合并的时候判断两个节点的父节点是否相同即可,相同则说明两节点已经在同一集合了,直接输出当前两节点。

3.Reference:108. 多余的边


KamaCoder109.多余的边II

109. 多余的边II

1.思路

这个图最初是一棵有n个节点的树(有n-1条边),然后被额外添加了一条有向边。由于添加了这条边,图可能不再是一棵树。这会导致两种可能的问题:

存在环:新添加的边连接了已经连通的两个节点;存在入度为2的节点:新添加的边指向了一个已经有入边的节点。

目标:找出这条被添加的“冗余”边,移除它后,图能重新变为一棵树。

情况一:存在入度为 2 的节点 (vec.size() > 0)

冗余边必定是edge1edge2中的一条,我们需要判断到底是哪一条。

首先尝试删除vec[1]对应的边,如果isdelete返回true,说明删除edge2后图是合法的, 那么edge2就是答案。如果isdelete返回false,说明删除edge2后图仍然有环。这意味 着edge1才是构成环的边,因此edge1是答案。

情况二:不存在入度为 2 的节点 (vec.size() == 0)

既然没有入度为 2 的节点,那么问题必定是存在一个环。而且,这个环就是由那条多 余的边造成的。

直接使用并查集遍历所有n条边,找到第一个构成环的边即可。

如果issame(u, v)true,说明uv已经连通,当前边(u, v)就是导致环的冗余边。直 接输出并结束程序。

如果issame(u, v)false,则执行join(u, v),继续检查下一条边。

#include <iostream> #include <vector> using namespace std; int n; vector<int>father(1005,1); void init(){ for(int i=1;i<=n;i++){ father[i]=i; } } int find(int u){ if(u==father[u]){ return u; } return father[u]=find(father[u]); } bool issame(int u,int v){ u=find(u); v=find(v); return u==v; } void join(int u,int v){ u=find(u); v=find(v); if(u==v) return; father[u]=v; } // 删一条边之后判断是不是树 bool isdelete(vector<pair<int,int>>&edges,int u){ init(); for(int i=1;i<=n;i++){ if(i==u) continue; if(issame(edges[i].first,edges[i].second)){ // 构成有向环了,一定不是树 return false; } else join(edges[i].first,edges[i].second); } return true; } int main(){ cin>>n; vector<pair<int,int>>edges(n+1); // 存边 vector<int>indegree(n+1,0); // 记录节点入度 for(int i=1;i<=n;i++){ int s,t;cin>>s>>t; edges[i]={s,t}; indegree[t]++; } vector<int>vec; // 找入度为2的节点所对应的边 for(int i=1;i<=n;i++){ if(indegree[edges[i].second]==2){ vec.push_back(i); } } if(vec.size()>0){ // 优先删vec[1] 对应这条边 if(isdelete(edges,vec[1])){ cout<<edges[vec[1]].first<<" "<<edges[vec[1]].second<<endl; } else cout<<edges[vec[0]].first<<" "<<edges[vec[0]].second<<endl; return 0; } // 明确没有入度为2的情况,那么一定有有向环,找到构成环的边返回就可以了 // 在有向图里找到删除的那条边,使其变成树 init(); for(int i=1;i<=n;i++){ if(issame(edges[i].first,edges[i].second)){ cout<<edges[i].first<<" "<<edges[i].second<<endl; return 0; } else join(edges[i].first,edges[i].second); } return 0; }

2.思考

这道题较上道题难度天差地别。有多余的边,我们就要讨论几种情况,第一种就是有入度为 2 的节点,那么显而易见,该节点相关的两条边中的一条就是冗余的边,那么此时我们就假设删除第二条边,然后看剩余边能否构成有向树,如果能,那么该条边就是冗余的,否则,第一条边就是冗余的;还有一种情况就不存在入度为 2 的节点,但此时还是存在冗余边,所以就是形成了环,此时也就来到了 多余的边 那道题的情况,只需要依次连接节点,遇到在同一集合的两节点,立即输出返回,此时两节点构成的边即为多余的边。

3.Reference:109. 冗余连接II | 代码随想录

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/22 16:15:03

微信网页版访问困境突破:3步安装wechat-need-web插件实战指南

你是否曾经在工作中急需使用微信网页版&#xff0c;却遭遇访问限制的困扰&#xff1f;在数字化办公时代&#xff0c;微信已经成为我们日常沟通不可或缺的工具&#xff0c;但网页版的访问问题却让无数用户头疼不已。今天&#xff0c;我们将为你揭秘一个简单有效的解决方案&#…

作者头像 李华
网站建设 2026/6/23 2:35:28

MFC扩展库BCGControlBar Pro v37.1——支持Visual Studio 2026

BCGControlBar库拥有500多个经过全面设计、测试和充分记录的MFC扩展类。 我们的组件可以轻松地集成到您的应用程序中&#xff0c;并为您节省数百个开发和调试时间。 BCGControlBar专业版 v37.1已全新发布了&#xff0c;新版本增加了对Visual Studio 2026的支持&#xff08;仅限…

作者头像 李华
网站建设 2026/6/20 5:31:32

知乎专题策划:LobeChat是否真的值得入手?

LobeChat 是否值得入手&#xff1f;一场关于自主 AI 未来的深度思考 在大模型浪潮席卷全球的今天&#xff0c;我们早已不再惊讶于 AI 能写诗、编程或回答复杂问题。真正让人纠结的是&#xff1a;如何安全、可控地使用这些能力&#xff1f; 当你在 ChatGPT 中输入一段代码需求时…

作者头像 李华
网站建设 2026/6/23 17:06:30

MTKClient:如何快速掌握联发科设备调试的核心技巧?

MTKClient&#xff1a;如何快速掌握联发科设备调试的核心技巧&#xff1f; 【免费下载链接】mtkclient MTK reverse engineering and flash tool 项目地址: https://gitcode.com/gh_mirrors/mt/mtkclient 你是否曾因联发科设备刷机失败而苦恼&#xff1f;是否面对复杂的…

作者头像 李华
网站建设 2026/6/23 18:36:31

国内云渲染平台有哪些公司?推荐及分析

随着数字化转型的深入&#xff0c;云计算技术已渗透至设计、影视、仿真等众多领域。云渲染作为其重要分支&#xff0c;凭借弹性算力、成本优化与协同效率等优势&#xff0c;正逐渐改变传统的高性能计算模式。对于企业及团队而言&#xff0c;如何选择一家可靠、高效且贴合业务需…

作者头像 李华