news 2026/1/2 12:51:39

AcWing 846:树的重心 ← 类似“东方博宜OJ 2190:树的重心”代码

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
AcWing 846:树的重心 ← 类似“东方博宜OJ 2190:树的重心”代码

【题目来源】
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


【算法代码:链式前向星
本文代码与“东方博宜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 10 out: 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/

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

Pinyin4NET终极指南:掌握.NET中文拼音转换的10个核心技巧

Pinyin4NET终极指南&#xff1a;掌握.NET中文拼音转换的10个核心技巧 【免费下载链接】Pinyin4NET c# 拼音汉字/姓相互转换工具库 (这只是镜像仓库&#xff0c;源仓库见 https://gitee.com/hyjiacan/Pinyin4Net) 项目地址: https://gitcode.com/gh_mirrors/pi/Pinyin4NET …

作者头像 李华
网站建设 2025/12/22 16:59:00

MATLAB图像导出专业指南:从入门到精通的完整解决方案

MATLAB图像导出专业指南&#xff1a;从入门到精通的完整解决方案 【免费下载链接】export_fig A MATLAB toolbox for exporting publication quality figures 项目地址: https://gitcode.com/gh_mirrors/ex/export_fig 还在为MATLAB导出的图像质量不佳而困扰吗&#xff…

作者头像 李华
网站建设 2026/1/1 17:28:54

3步让你的Obsidian笔记变身高颜值知识库:AnuPpuccin主题深度体验

3步让你的Obsidian笔记变身高颜值知识库&#xff1a;AnuPpuccin主题深度体验 【免费下载链接】AnuPpuccin Personal theme for Obsidian 项目地址: https://gitcode.com/gh_mirrors/an/AnuPpuccin 还在使用默认的Obsidian界面吗&#xff1f;AnuPpuccin主题作为2022年度最…

作者头像 李华
网站建设 2026/1/1 1:18:06

微信自动化开发终极指南:从零到一的完整解决方案

在当今数字化办公环境中&#xff0c;微信作为重要的沟通工具&#xff0c;其自动化需求日益增长。本文为您详细介绍如何利用wxhelper工具实现PC端微信的全面自动化&#xff0c;让繁琐的重复操作变得简单高效。 【免费下载链接】wxhelper Hook WeChat / 微信逆向 项目地址: htt…

作者头像 李华
网站建设 2025/12/12 8:17:37

如何快速掌握MajesticAdmin:企业级后台系统的终极使用指南

如何快速掌握MajesticAdmin&#xff1a;企业级后台系统的终极使用指南 【免费下载链接】MajesticAdmin-Free-Bootstrap-Admin-Template Simple Bootstrap 4 Dashboard template. 项目地址: https://gitcode.com/gh_mirrors/ma/MajesticAdmin-Free-Bootstrap-Admin-Template …

作者头像 李华
网站建设 2026/1/2 2:33:48

2025年木质台历供应商调研,云边包装表现亮眼

木质台历作为一种兼具实用性和装饰性的办公及家居用品&#xff0c;近年来市场需求持续增长。随着消费者对个性化、环保产品需求的提升&#xff0c;木质台历定制服务日益受到青睐。本次调研旨在分析2025年木质台历供应商市场表现&#xff0c;为消费者和企业提供参考依据。本次调…

作者头像 李华