news 2026/5/1 9:47:19

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/4/23 11:58:55

凤希AI伴侣的服饰探索与虚拟现实畅想-2026年1月26日

思考与发现今天在利用AI生图功能为凤希AI伴侣设计不同民族服饰的过程中&#xff0c;深刻感受到了AI技术带来的文化探索可能性。我们无需亲身踏足世界各地&#xff0c;就能通过AI生成的视觉内容&#xff0c;领略不同民族的风土人情与服饰文化。这不仅是技术应用&#xff0c;更是…

作者头像 李华
网站建设 2026/5/1 9:09:09

探索汇川H3U标准程序:多轴伺服定位的宝藏案例

汇川H3U标准程序&#xff0c;程序有本体脉冲控制的三轴伺服定位&#xff0c;另有总线控制的16轴汇川伺服定位&#xff0c;程序包含轴点动&#xff0c;回零&#xff0c;相对定位绝对定位&#xff0c;程序结构清晰&#xff0c;分模块控制&#xff0c;是工控者学习的好案例。 在工…

作者头像 李华
网站建设 2026/4/30 16:37:43

基于狼群优化算法的LSSVM回归预测:GWO - LSSVM的探索

基于狼群优化算法的LSSVM回归预测GWO-LSSVM 其他优化算法可私信 为了提高最小二乘支持向量机&#xff08;lssvm&#xff09;的回归预测准确率&#xff0c;对lssvm中的惩罚参数和核惩罚参数利用狼群优化算法进行优化。 Matlab 代码 在数据预测的领域中&#xff0c;提高预测准确…

作者头像 李华
网站建设 2026/5/1 9:14:34

基于IEEE33的主动配电网优化探索

基于IEEE33的主动配电网优化。 采用IEEE33节点配电网进行仿真&#xff0c;搭建了含风光&#xff0c;储能&#xff0c;柴油发电机和燃气轮机的配电网经济调度模型。 以总的运行成本最小为目标&#xff0c; 考虑了储能以及潮流等约束&#xff0c; 采用粒子群算法对模型进行求解&a…

作者头像 李华
网站建设 2026/5/1 7:27:19

风电调频并网系统之 4 机 2 区模型探秘

风电调频并网系统&#xff0c;两区域四机系统 &#xff0c;4机2区模型。 适合大尺度仿真&#xff0c;仅需5秒即可仿真出60s内容。 参考自pkunder 的电力系统稳定与控制。 内含有四种PSS模式 最近在研究风电调频并网系统&#xff0c;发现其中的4机2区模型&#xff08;两区域四机…

作者头像 李华
网站建设 2026/4/30 23:57:35

蓄电池与超级电容混合储能并网的 Simulink 仿真探索

蓄电池与超级电容混合储能并网matlab/simulink仿真模型&#xff0c;混合储能采用低通滤波器进行功率分配&#xff0c;可有效抑制功率波动&#xff0c;并对超级电容的soc进行能量管理&#xff0c;soc较高时多放电&#xff0c;较低时少放电&#xff0c;soc较低时状态与其相反。在…

作者头像 李华