尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

AcWing 846:树的重心 ← 链式前向星 or 邻接表

AcWing 846:树的重心 ← 链式前向星 or 邻接表
📅 发布时间:2026/6/21 12:47:00

​【题目来源】
https://www.acwing.com/problem/content/848/

【问题描述】
给定一颗树,树中包含 n 个结点(编号 1∼n)和 n−1 条无向边。
请你找到树的重心,并输出将重心删除后,剩余各个连通块中点数的最大值。
重心定义:重心是指树中的一个结点,如果将这个点删除后,剩余各个连通块中点数的最大值最小,那么这个节点被称为树的重心。

【输入格式】
第一行包含整数 n,表示树的结点数。
接下来 n−1 行,每行包含两个整数 a 和 b,表示点 a 和点 b 之间存在一条边。

【输出格式】
输出一个整数 m,表示将重心删除后,剩余各个连通块中点数的最大值。

【数据范围】
1≤n≤10^5

【输入样例】
9
1 2
1 7
1 4
2 8
2 5
4 3
3 9
4 6

【输出样例】
4

【算法分析】
● 链式前向星:https://blog.csdn.net/hnjzsyjyj/article/details/139369904
● 邻接表存“树”:https://blog.csdn.net/hnjzsyjyj/article/details/108655516

【算法代码一:链式前向星】

#include <bits/stdc++.h>
using namespace std;const int N=1e5+10;
const int M=N<<1;
int h[N],e[M],ne[M],idx;
bool st[N];
int imax=INT_MAX;
int n;void add(int a,int b) {e[idx]=b,ne[idx]=h[a],h[a]=idx++;
}int dfs(int u) {st[u]=true;int cnt=1;int rem=0; //remnantfor(int i=h[u]; i!=-1; i=ne[i]) {int j=e[i];if(!st[j]) {int t=dfs(j);rem=max(rem,t);cnt+=t;}}rem=max(rem,n-cnt);imax=min(imax,rem);return cnt;
}int main() {cin>>n;memset(h,-1,sizeof(h));for(int i=1; i<n; i++) {int a,b;cin>>a>>b;add(a,b),add(b,a);}dfs(1);cout<<imax<<endl;return 0;
}/*
in:
9
1 2
1 7
1 4
2 8
2 5
4 3
3 9
4 6out:
4
*/

【算法代码二:邻接表】

#include<bits/stdc++.h>
using namespace std;const int N=1e5+5;
vector<int> G[N];
bool st[N];
int imax=INT_MAX;
int n;int dfs(int u) {st[u]=true;int cnt=1;int rem=0; //remnantfor(auto i:G[u]) {if(!st[i]) {int t=dfs(i);rem=max(rem,t);cnt+=t;}}rem=max(rem,n-cnt);imax=min(rem,imax);return cnt;
}int main() {cin>>n;int x,y;for(int i=1; i<n; i++) {cin>>x>>y;G[x].push_back(y);G[y].push_back(x);}dfs(1);cout<<imax<<endl;return 0;
}/*
in:
9
1 2
1 7
1 4
2 8
2 5
4 3
3 9
4 6out:
4
*/

 【算法代码三:链式前向星】
此代码与“东方博宜OJ 2190:树的重心”代码的差别,仅在于最后一部分的循环内容不同。
详见:https://blog.csdn.net/hnjzsyjyj/article/details/155821553

#include <bits/stdc++.h>
using namespace std;const int N=1e5+5;
const int M=N<<1;
int h[N],e[M],ne[M],idx;
int pre[N],cnt[N];
int rem[N]; //remnant
int n;void add(int a,int b) {e[idx]=b,ne[idx]=h[a],h[a]=idx++;
}int dfs(int u,int fa) {cnt[u]=1;pre[u]=fa;for(int i=h[u]; i!=-1; i=ne[i]) {int j=e[i];if(j!=fa) cnt[u]+=dfs(j,u);}return cnt[u];
}int main() {memset(h,-1,sizeof h);cin>>n;for(int i=1; i<n; i++) {int a,b;cin>>a>>b;add(a,b),add(b,a);}dfs(1,-1);int imin=INT_MAX;for(int u=1; u<=n; u++) {rem[u]=n-cnt[u];for(int i=h[u]; i!=-1; i=ne[i]) {int j=e[i];if(pre[j]==u) {rem[u]=max(rem[u],cnt[j]);}}imin=min(imin,rem[u]);}int imax=INT_MIN;for(int u=1; u<=n; u++) {if(imin==rem[u]) {int t=0;for(int i=h[u]; i!=-1; i=ne[i]) {int j=e[i];if(pre[j]==u) {t=max(t,cnt[j]);}}t=max(t,n-cnt[u]);imax=max(imax,t);}}cout<<imax<<endl;return 0;
}/*
in:
10
1 2
1 3
4 2
4 5
3 6
7 6
8 6
9 6
7 10out:
5
*/





【参考文献】
https://blog.csdn.net/hnjzsyjyj/article/details/155821553
https://www.acwing.com/solution/content/287387/
https://blog.csdn.net/hnjzsyjyj/article/details/139369904
https://blog.csdn.net/hnjzsyjyj/article/details/108655516
https://blog.csdn.net/qq_47783057/article/details/116195481
https://www.acwing.com/solution/content/13513/
https://www.acwing.com/solution/content/4917/

 

 

​

相关新闻

  • 251211
  • Python自然语言处理的未来:技术栈与开发范式
  • 观察者模式

最新新闻

  • 2026年靠谱的集装箱/移动集装箱/昆明集装箱精选厂家推荐 - 品牌宣传支持者
  • AssetStudio终极指南:5分钟掌握Unity资源提取的核心技巧
  • Ubuntu 20.04 下 MongoDB 安全加固:从默认裸跑到认证启用
  • Python实战RSA算法:从数论原理到完整加密引擎实现
  • 2026年知名的大连驾校快速拿证/大连驾校大学生学车/大连驾校口碑排行榜 - 行业平台推荐
  • 2026年靠谱的台州短视频拍摄/工厂短视频/台州短视频服务型公司推荐 - 行业平台推荐

日新闻

  • 2026速览惠州叛逆青少年学校前十大排名名单出炉 - 武汉中职最新信息发布
  • 2026上饶白蚁消杀哪家好?15年本土2大权威白蚁防治公司推荐(金盾虫控/青蚁卫士) - 我叫一
  • 天龙八部单机版终极数据管理工具:5个技巧快速掌握游戏数据编辑

周新闻

  • Visual C++运行库修复终极指南:5分钟快速解决Windows软件启动错误
  • 手把手教你构建统计局地区经济数据爬虫:从环境搭建到数据持久化全指南
  • 2026多Agent深度解析:用AI团队替代单一模型,四种架构实战落地

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号