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

P3629 [APIO2010] 巡逻

P3629 [APIO2010] 巡逻

大意

给定一棵有 \(n\) 个节点的树,巡警车从 \(1\) 号节点出发遍历所有边后返回,每条边需经过两次,总距离为 \(2*(n-1)\)。现可新建 \(K\) 条边\((k = \{ 1, 2\})\),要求新建的每条边必须恰好经过一次,求规划新建边的方案,使得巡警车的总巡逻距离最小,并输出该最小值。

思路

我们可以发现,对于 \(k = 1\) 的情况,显然你求出一条直径,再把直径的两个端点连上,这样是最优的。

但是当 \(k = 2\) 的时候,我们需要再连一次,但是这样的话,我们最好选比较长的,最初的想法是选次长的直径,但是我们想想,如果你选的这条新的直径,和原来的直径,有很多重合的点,那么就不是很优,我们为了处理这个重复的玩意,其实可以把原直径的所有边赋为 \(-1\),这样的话,我们再找最长的直径,就不会出问题了。

但是这样需要知道一个问题, dfs 求直径是无法解决边权为负的情况,于是我们考虑树形 dp 的方式,直接再记一次直径的长度即可。

设两次的直径长度为 \(L_1, L_2\),则最终答案为:

\(k = 1\) 时:\(2 * (n - 1) - L_1 + 1\)

\(k = 2\) 时:\(2 * (n - 1) - (L_1 - 1) - (L_2 - 1)\)

代码

#include<iostream>
#include<cstring>
using namespace std;const int MAXN = 1e5 + 5;struct node{int to, nxt, len;
}e[MAXN * 2];int tot = 0, h[MAXN];
int d[MAXN];
bool vis[MAXN];void add(int x, int y, int len){e[++ tot] = {y, h[x], len};h[x] = tot;
}int n, k, d1 = 1, d2 = 0, d3 = 1, d4 = 0;
int f[MAXN];
int dp[MAXN], maxx;void dfs(int u, int fa){dp[u] = 0;for(int i = h[u]; i; i = e[i].nxt){int v = e[i].to;if(v == fa) continue;e[i].len = (vis[u] && vis[v]) ? -1 : 1;dfs(v, u);maxx = max(maxx, dp[u] + dp[v] + e[i].len);dp[u] = max(dp[u], dp[v] + e[i].len);}
}void dfs1(int u, int fa){for(int i = h[u];i;i = e[i].nxt){int v = e[i].to;if(v == fa) continue;d[v] = d[u] + e[i].len;if(d[v] > d[d1]){d1 = v;}dfs1(v, u);}
}void dfs2(int u, int fa){f[u] = fa;for(int i = h[u];i;i = e[i].nxt){int v = e[i].to;if(v == fa) continue;d[v] = d[u] + e[i].len;if(d[v] > d[d2]){d2 = v;}dfs2(v, u);}
}int main(){cin >> n >> k;for(int i = 1;i < n;i ++){int a, b; cin >> a >> b;add(a, b, 1), add(b, a, 1);}dfs1(1, 0);memset(d, 0, sizeof(d));dfs2(d1, 0);int l1 = d[d2];if(k == 1){cout << 2 * (n - 1) - l1 + 1 << '\n';return 0;}memset(vis, 0, sizeof(vis));int tmp = d2;while(tmp != 0){vis[tmp] = true;tmp = f[tmp];}maxx = 0;dfs(1, 0);int l2 = maxx;cout << 2 * (n - 1) - (l1 - 1) - (l2 - 1) << '\n';return 0;
}
http://www.jsqmd.com/news/94829/

相关文章:

  • AI 时代 GEO 营销先锋盘点:五大服务商助力 ToB 企业精准获客 - 品牌2025
  • SMB、FTP、MySQL... 配置不当,即是漏洞
  • 选择写论文软件哪个好?别让错误的工具,成为你学术路上“甜蜜的陷阱”
  • 32 低功耗模式(睡眠 停机 待机 )
  • 学术 “智造局”—— 虎贲等考 AI,承包你论文从选题到定稿的全周期智能服务
  • 告别选题迷茫、文献繁杂、写作卡顿!虎贲等考 AI,学术研究全流程智能引擎,做你的私人学术加速器
  • 深入解析:LeetCode 51 - N皇后问题 详解笔记
  • 豆包 AI 手机登录微信被「踢下线」,原因为何?端侧 AI 与头部应用的生态兼容上存在哪些挑战?
  • leetcode 754. Reach a Number 到达终点数字-耗时100%
  • Java毕设选题推荐:基于springboot高校奖助学金系统设计与实现基于springboot高校学生奖学金评定系统的设计与实现【附源码、mysql、文档、调试+代码讲解+全bao等】
  • 实用指南:UE5笔记:OnComponentBeginOverlap
  • 豆包手机助手技术预览版发布,AI直接嵌入操作系统底层有何意义?会对行业产生什么影响?
  • 校园招聘会组织不再难,统筹安排让就业季更顺畅
  • 【毕业设计】基于springboot人才公寓管理系统基于springboot公寓管理系统(源码+文档+远程调试,全bao定制等)
  • JSON 与 MongoDB:直存对象的便利与隐性代价
  • 【Agent】MemOS 源码笔记---(5)---记忆分类
  • 靠谱的 AI 智能体获客落地指导,2025 年 12 月除了麟哥还有谁?
  • 销售助手-生产模型反馈闭环
  • 【原创代码改进】基于IVY(常青藤优化算法)-BiTCN(双向时域卷积网络)-BiGRU(双向门控循环单元)的多变量时间序列回归
  • NO17数据结构选择题考点|图
  • 2026年最强翻译工具——不是常规的机翻!
  • 智慧校园招投标流程中的时间管理要点:如何把握关键节点
  • cpp_studing_day1
  • 国产期刊被EI收录!首个影响因子12分,录用率67%,国人友好~
  • 质子交换膜燃料电池(PEMFC Simulink模型) (1)仿真内容:包括燃料电池静态模型、...
  • Java毕设选题推荐:基于springboot高校师资管理系统教师管理、学院管理、专业信息管理、职称调整管理、课程安排管理、进修学习管理、进修汇【附源码、mysql、文档、调试+代码讲解+全bao等】
  • openFuyao 容器平台快速入门:Nginx 应用部署全流程实操
  • Java毕设选题推荐:基于SpringBoot+Vue智能公寓管理系统基于springboot公寓管理系统【附源码、mysql、文档、调试+代码讲解+全bao等】
  • 二维傅里叶变换算法及其完整流程:提取频谱波峰、反变换、相位角分布与解包应用于干涉图处理
  • 【课程设计/毕业设计】基于springboot果蔬种植销售一体化服务平台的设计与实现果蔬信息、果蔬入库【附源码、数据库、万字文档】