news 2026/3/13 3:00:24

20250124树的直径总结

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
20250124树的直径总结

需要说吗?

直径

直径为树上一条边权和最长的简单路径,以下是直径的一些常用性质:

  1. 树的直径不一定唯一
  2. 树的直径的端点一定是度数为1的点
  3. 若直径有数条,那么所有直径交汇于至少一点
  4. 树上任一点距离其最远的点一定是直径的两个端点之一
  5. 在叶子节点处增加或删除一条边,直径至多增减1(边权为负数除外)
  6. 给定2棵树,添加一条边连接两棵树,新的树的直径至少为
    max((d1+1)/2+(d2+1)/2+w,d1,d2)

具体实现方法为两遍DFS或BFS,第一次从任一点出发,找到离该点最远的点x,然后再调一次函数找到离x最远的点y,Sx->y就是直径的长度。

知道了这些相信你一定可以做出模板题了!

B4016 树的直径

模板参考代码注释即可。

#include<bits/stdc++.h>usingnamespacestd;vector<int>E[100005];intans=0,X,Y;voiddfs(intx,intfa,intid,intsum){if(sum>=ans){//如果目前的距离比原来更好就更新//等于为什么要更新呢?这是因为第二次深搜时ans没有清零,或者清零也行//可能第二次深搜答案刚好等于第一次深搜的答案,于是y就没有更新,最好加个等于号ans=sum;if(id==1){//第一次深搜X=x;}else{Y=x;}}for(inti=0;i<E[x].size();i++){intv=E[x][i];if(v==fa)continue;dfs(v,x,id,sum+1);//距离加一}}intmain(){intn;cin>>n;for(inti=1;i<n;i++){intu,v;cin>>u>>v;E[u].push_back(v);E[v].push_back(u);}dfs(1,0,1,0);//第一次从任一点出发dfs(X,0,2,0);//第二次从x点出发cout<<ans;return0;}

CF1404B Tree Tag

看题可得知题意:alice和bob依次在一棵树上轮流移动移动da和db的距离,问alice能否追到bob。

首先初始时如果它们之间的距离比da小,那么alice必胜,因为她先手,距离过小时可以直接抓到。就比如你要抓博尔特,贴脸抓,他还没开始跑你一伸手就抓到他了。

否则接着alice考虑最优策略:跑到直径的中间位置,这样她距离所有点最近,这样如果直径的一半向上取整小于等于da,那么alice必胜,因为这样无论bob跑到哪alice抓一下就抓到了。就比如你要抓博尔特,在厕所里面抓,博尔特无论跑到哪你都一定抓得到。

再否则不行,那么alice考虑最后的最优策略:把bob逼到叶子节点去,假设bob已经到叶子节点了,他还要脱离的话就得一次跳过alice的捕捉范围,也就是说要bob胜必须db>da*2,否则alice胜。就比如你要抓博尔特,在死胡同里抓,博尔特跑到最里面除非从你头上跳过去否则你都一定抓得到。

#include<bits/stdc++.h>usingnamespacestd;vector<int>E[100005];intans=0,X,dis[100005];voiddfs(intx,intfa,intsum){//找直径长度dis[x]=sum;if(sum>=ans){ans=sum;X=x;}for(inti=0;i<E[x].size();i++){intv=E[x][i];if(v==fa)continue;dfs(v,x,sum+1);}}intmain(){intt;cin>>t;while(t--){memset(dis,0,sizeofdis);ans=X=0;intn,a,b,da,db;cin>>n>>a>>b>>da>>db;for(inti=1;i<=n;i++)E[i].clear();for(inti=1;i<n;i++){intu,v;cin>>u>>v;E[u].push_back(v);E[v].push_back(u);}dfs(a,0,0);intggy=dis[b];dfs(X,0,0);if(ggy<=da||db<=da*2||(ans+1)/2<=da){cout<<"Alice"<<endl;}else{cout<<"Bob"<<endl;}}return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/11 16:52:45

西门子 S7 - 1200 PLC 在污水处理项目中的实战应用

西门子S7一1200 PLc程序项目&#xff0c;cPU1214和ET200 iO站点&#xff0c;博途V16与V17版&#xff0c;HMi为kTP1200.模拟量转换&#xff0c;电动阀控制&#xff0c;液位控制&#xff0c;Modbus通讯控制变频器&#xff0c;Pid控制&#xff0c;PUt与get指令&#xff0c;汅水处…

作者头像 李华
网站建设 2026/3/11 14:19:10

Turbo码编码译码在MATLAB中的实现探索

Turbo码编码译码 MATLAB 实现 不同算法 log—MAP max—log—map sova算法 在通信领域&#xff0c;Turbo码以其优异的性能备受关注。它通过交织器和分量编码器构建了一种并行级联卷积码&#xff0c;实现了接近香农限的纠错能力。今天咱们就来聊聊Turbo码编码译码在MATLAB里怎么实…

作者头像 李华
网站建设 2026/3/12 14:55:54

无人驾驶动力学MPC算法跟踪蛇形线探索

无人驾驶动力学mpc算法跟踪蛇形线)。在无人驾驶领域&#xff0c;精确的路径跟踪是关键技术之一。今天咱来聊聊用动力学MPC&#xff08;Model Predictive Control&#xff0c;模型预测控制&#xff09;算法实现对蛇形线的跟踪。 蛇形线的魅力与挑战 蛇形线可不是简单的路径。它有…

作者头像 李华
网站建设 2026/3/11 20:14:57

综合能源系统优化在MATLAB - Yalmip - CPLEX平台上的实现

综合能源系统优化 数据来源《考虑需求响应的社区综合能源系统两阶段优化调度_刘蓉晖》 %% 风电储能电网交易燃气轮机燃气锅炉电制冷机&#xff08;%燃料电池FC溴化锂制冷机LBR余热锅炉&#xff09; 有电负荷热负荷冷负荷 加上环境成本 没有后面的二阶段哦&#xff01; 简单 注释…

作者头像 李华
网站建设 2026/3/12 7:44:16

光伏系统遮阴下MPPT的MATLAB探索:从传统粒子群到动态遮阴优化

MATLAB模型&#xff0c;采用粒子群PSO&#xff0c;适用于光伏系统中遮阴下的mppt最大功率跟踪&#xff0c;有扰动PO&#xff0c;传统粒子群&#xff0c;以及改进后加入重启能进行动态遮阴的三个模块。在光伏系统领域&#xff0c;最大功率点跟踪&#xff08;MPPT&#xff09;技术…

作者头像 李华