当前位置: 首页 > news >正文

树的重心(邻接表)

image

输入样例:

9
1 2
1 7
1 4
2 8
2 5
4 3
3 9
4 6

期望输出:

4

代码实现:

#include<bits/stdc++.h>
using namespace std;const int N =1e5+10 , M=2*N;int n,m;
int h[N],e[M],ne[M],idx;
bool vis[N];
int ans=N ;void add(int a,int b)//插入一条a指向b的边
{e[idx]=b;ne[idx]=h[a];h[a]=idx++;
}int dfs(int u)//u代表的是第几个点
{vis[u]=1;int sum = 1,res =0; //sum 为当前子树的大小,res为把这一点删除后的连通块的最大值for(int i=h[u];i!=-1;i=ne[i]){int k=e[i];if(!vis[k]){int s = dfs(k); //当前子树的大小res = max(res,s);//看看所有子树哪个更大sum +=s;//求自己为父节点树的大小}}res = max(res,n-sum); //看看删除这个点的其他部分与最大子树哪个大ans = min(ans,res);//找到最小的答案return sum;
}int main()
{cin>>n;memset(h,-1,sizeof(h));for(int i=0;i<n-1;i++){int a ,b;cin>>a>>b;add(a,b);add(b,a);//因为是无向图,所以要新建两条边}dfs(1);//从哪个点开始搜cout<<ans<<endl;
}

  

http://www.jsqmd.com/news/4136/

相关文章:

  • 语音芯片怎样接? 语音芯片有哪些常见接口类型?
  • 详细介绍:2025华为杯A题B题C题D题E题F题选题建议思路数学建模研研究生数学建模思路代码文章成品
  • Gitee vs. GitLab:中国开发者为何选择本土代码托管平台?
  • AtCoder Beginner Contest 424
  • US$39 BAV-Key Adapter for Yanhua Mini ACDP
  • ClkLog埋点分析系统-私有化部署+轻量灵活
  • 级数 - Emi
  • 基于 Docker 的 Nginx + OpenSSL 自签名证书启用 HTTPS
  • PolarFire Soc System Services
  • 基于STM32的正弦波逆变器设计
  • 深入解析:SDL2视频渲染
  • 高校固定资产管理高效的系统——Java EE毕业设计资源包
  • ======================================分割线======================================
  • OpenLayers地图交互 -- 章节六:范围交互详解 - 实践
  • 标准卷积和空洞卷积--适应不同尺寸的输入--ASPP模块
  • 游戏在高负载场景下,整机功耗控制在多少
  • 打印机状态错误,怎么恢复正常打印?
  • 使用Ollama 0.12.2本地部署大模型,友好界面对话,开启飞行模式数据完全存在本地
  • 7timer.info 免费天气预报对接记录
  • 牛客刷题-Day5
  • 详细介绍:四大金刚之计算机网络
  • 用标准版平板干翻上代Pro,小米又想学苹果了?
  • VonaJS多租户同时支持共享模式和独立模式
  • 记录一下第一次为Dify贡献插件的经历
  • 物联网字节校验常用方法
  • 实用指南:RabbitMQ 核心组件详解与持久化日志队列实现方案
  • 实用指南:【C语言】统计二进制中1的个数:三种方法的比较与分析
  • Visual Prompt Builder-AI 提示词可视化工具 - 详解
  • STM32H743-ARM例程2-UART命令控制LED - 实践
  • 完整教程:Zookeeper与Kafka:分布式系统中的协调与消息队列