news 2026/4/12 17:55:42

GESP认证C++编程真题解析 | P11251 [GESP202409 八级] 美丽路径

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
GESP认证C++编程真题解析 | P11251 [GESP202409 八级] 美丽路径

​欢迎大家订阅我的专栏:算法题解:C++与Python实现!
本专栏旨在帮助大家从基础到进阶 ,逐步提升编程能力,助力信息学竞赛备战!

专栏特色
1.经典算法练习:根据信息学竞赛大纲,精心挑选经典算法题目,提供清晰的代码实现与详细指导,帮助您夯实算法基础。
2.系统化学习路径:按照算法类别和难度分级,从基础到进阶,循序渐进,帮助您全面提升编程能力与算法思维。

适合人群:

  • 准备参加蓝桥杯、GESP、CSP-J、CSP-S等信息学竞赛的学生
  • 希望系统学习C++/Python编程的初学者
  • 想要提升算法与编程能力的编程爱好者

附上汇总帖:GESP认证C++编程真题解析 | 汇总


【题目来源】

洛谷:P11251 [GESP202409 八级] 美丽路径 - 洛谷

【题目描述】

小杨有一棵包含n nn个节点的树,节点从1 11n nn编号,并且每个节点要么是白色,要么是黑色。

对于树上的一条简单路径(不经过重复节点的路径),小杨认为它是美丽的当且仅当路径上相邻节点的颜色均不相同。例如下图,其中节点1 11和节点4 44是黑色,其余节点是白色,路径2 − 1 − 3 − 4 2-1-3-42134是美丽路径,而路径2 − 1 − 3 − 5 2-1-3-52135不是美丽路径(相邻节点3 335 55颜色相同)。

对于树上的一条简单路径,小杨认为它的长度是路径包含节点的数量。小杨想知道最长的美丽路径的长度是多少。

【输入】

第一行包含一个正整数n nn,代表节点数量。

第二行包含n nn个整数c 1 , c 2 , … , c n c_1,c_2,\dots,c_nc1,c2,,cn,代表每个节点的颜色,如果c i = 0 c_i=0ci=0,代表节点i ii为白色,如果c i = 1 c_i=1ci=1,代表节点i ii为黑色。

之后n − 1 n-1n1行,每行包含两个正整数u i , v i u_i,v_iui,vi,代表存在一条连接节点u i u_iui和节点v i v_ivi的边。

【输出】

输出一个整数,代表最长美丽路径的长度。

【输入样例】

5 1 0 0 1 0 1 2 3 5 4 3 1 3

【输出样例】

4

【算法标签】

《洛谷 P11251 美丽路径》 #动态规划DP# #GESP# #2024#

【代码详解】

#include<bits/stdc++.h>usingnamespacestd;constintN=100005,M=N*2;intn;// 节点数量intc[N];// c[i] 表示节点i的颜色intf1[N];// f1[i]: 以节点i为起点的最长同色路径长度intf2[N];// f2[i]: 以节点i为起点的次长同色路径长度intans;// 最终答案(路径上的节点数-1,即最大长度)inth[N],e[M],ne[M],idx;// 邻接表存储树// 添加无向边voidadd(inta,intb){e[idx]=b;ne[idx]=h[a];h[a]=idx++;}// 深度优先搜索// u: 当前节点// fa: 父节点voiddfs(intu,intfa){// 遍历所有邻接节点for(inti=h[u];i!=-1;i=ne[i]){intj=e[i];// 邻接节点if(j==fa)// 跳过父节点{continue;}// 递归处理子树dfs(j,u);// 计算从当前节点u到子节点j的路径长度// 如果u和j颜色不同,路径长度为f1[j]+1,否则为0intt=(c[u]!=c[j]?f1[j]+1:0);// 更新f1[u]和f2[u]if(t>f1[u]){f2[u]=f1[u];// 原来的最大值变为次大值f1[u]=t;// 更新最大值}elseif(t>f2[u]){f2[u]=t;// 更新次大值}}// 更新答案:考虑经过节点u的最长同色路径// 注意:这里计算的是路径上的边数,而不是节点数ans=max(ans,f1[u]+f2[u]);}intmain(){cin>>n;// 初始化邻接表memset(h,-1,sizeof(h));idx=0;// 读取每个节点的颜色for(inti=1;i<=n;i++){cin>>c[i];}// 读取树的边for(inti=1;i<n;i++){intu,v;cin>>u>>v;add(u,v);add(v,u);}// 从节点1开始DFSdfs(1,0);// 输出结果:最长同色路径的节点数 = 边数 + 1cout<<ans+1<<endl;return0;}

【运行结果】

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

成为TensorFlow镜像官方文档贡献者全过程

成为TensorFlow镜像官方文档贡献者全过程 在AI技术席卷全球的今天&#xff0c;一个看似不起眼却至关重要的问题正悄然影响着百万开发者的日常&#xff1a;为什么我打不开TensorFlow官网&#xff1f; 对于国内开发者而言&#xff0c;这早已不是新鲜事。尽管Google推出的Tensor…

作者头像 李华
网站建设 2026/4/12 17:49:18

如何撰写基于TensorFlow镜像的技术白皮书

基于TensorFlow镜像的AI工程化实践&#xff1a;从开发到部署的一致性保障 在企业级人工智能系统日益复杂的今天&#xff0c;一个常见的场景是&#xff1a;数据科学家在本地训练好的模型&#xff0c;一旦进入测试或生产环境就“水土不服”——依赖冲突、版本错乱、GPU不兼容………

作者头像 李华
网站建设 2026/4/4 3:58:50

如何引用TensorFlow镜像作为学术研究的技术基础

如何引用TensorFlow镜像作为学术研究的技术基础 在深度学习研究日益普及的今天&#xff0c;一个常见的尴尬场景是&#xff1a;论文中描述的模型在评审人或复现者手中“跑不起来”。代码能编译&#xff0c;却因环境差异导致训练崩溃、精度偏差&#xff0c;甚至完全无法运行。这种…

作者头像 李华
网站建设 2026/4/7 19:20:54

移动端AI实现路径:TensorFlow Lite集成指南

移动端AI实现路径&#xff1a;TensorFlow Lite集成指南 在智能手机和物联网设备无处不在的今天&#xff0c;用户对“即时响应”和“隐私安全”的要求越来越高。你有没有遇到过这样的场景&#xff1f;拍照识别延迟卡顿、语音助手必须联网才能工作、智能相机频繁上传数据引发隐私…

作者头像 李华
网站建设 2026/4/6 0:50:58

如何为TensorFlow镜像中的模型添加输入验证机制

如何为TensorFlow镜像中的模型添加输入验证机制 在工业级AI系统中&#xff0c;一个常见的“意外”是&#xff1a;模型本身准确率高达98%&#xff0c;但上线后频繁崩溃。排查日志发现&#xff0c;问题并非出在训练数据或架构设计上&#xff0c;而是客户端传入了一张尺寸为1024x7…

作者头像 李华
网站建设 2026/4/9 9:40:28

当学术写作遇上AI协作者:书匠策如何悄然重塑论文写作的“静默生产力

在人工智能席卷各行各业的当下&#xff0c;科研工作者的日常却似乎仍被大量重复性劳动所裹挟&#xff1a;文献筛选耗时费力、逻辑结构反复调整、语言表达屡屡卡壳、格式规范琐碎烦人……这些“看不见的摩擦力”&#xff0c;正在悄悄吞噬研究者的创造性能量。有没有一种可能&…

作者头像 李华