news 2026/4/18 2:06:34

GESP认证C++编程真题解析 | P10723 [GESP202406 七级] 黑白翻转

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
GESP认证C++编程真题解析 | P10723 [GESP202406 七级] 黑白翻转

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

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

适合人群:

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

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


【题目来源】

洛谷:[P10723 GESP202406 七级] 黑白翻转 - 洛谷

【题目描述】

小杨有一棵包含n nn个节点的树,这棵树上的任意一个节点要么是白色,要么是黑色。小杨认为一棵树是美丽树当且仅当在删除所有白色节点之后,剩余节点仍然组成一棵树。

小杨每次操作可以选择一个白色节点将它的颜色变为黑色,他想知道自己最少要执行多少次操作可以使得这棵树变为美丽树。

【输入】

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

第二行包含n nn个非负整数a 1 , a 2 , … , a n a_1,a_2,\ldots,a_na1,a2,,an,其中如果a i = 0 a_i=0ai=0,则节点i ii的颜色为白色,否则为黑色。

之后n − 1 n-1n1行,每行包含两个正整数x i , y i x_i,y_ixi,yi,代表存在一条连接节点x i x_ixiy i y_iyi的边。

【输出】

输出一个整数,代表最少执行的操作次数。

【输入样例】

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

【输出样例】

2

【算法标签】

《洛谷 P10723 黑白翻转》 #树形DP# #拓扑排序# #树的遍历# #GESP# #2024#

【代码详解】

#include<bits/stdc++.h>usingnamespacestd;constintN=100005,M=N*2;// M是边数的两倍,因为是无向图intn,ans;// n: 节点数, ans: 答案inta[N];// a[i]: 节点i的状态,0表示白色,1表示黑色inth[N],e[M],ne[M],idx;// 邻接表存储树结构// 添加无向边voidadd(inta,intb){e[idx]=b;// 存储边的终点ne[idx]=h[a];// 将新边插入链表头部h[a]=idx;// 更新头指针idx++;// 边编号自增}// 深度优先搜索// u: 当前节点// fa: 父节点,防止走回头路voiddfs(intu,intfa){ints=0;// 统计子节点中黑色节点的数量// 遍历当前节点的所有邻居for(inti=h[u];i!=-1;i=ne[i]){intj=e[i];// 邻居节点if(j==fa)// 如果是父节点,跳过{continue;}// 递归处理子树dfs(j,u);// 累加子节点的颜色s+=a[j];}// 关键条件判断:// 1. s > 0: 当前节点至少有一个黑色子节点// 2. a[u] == 0: 当前节点是白色if(s&&!a[u]){ans++;// 答案加1a[u]=1;// 将当前节点染成黑色}}intmain(){// 输入节点数cin>>n;// 初始化邻接表memset(h,-1,sizeof(h));// 输入每个节点的初始颜色for(inti=1;i<=n;i++){cin>>a[i];}// 输入n-1条边,构建树for(inti=1;i<n;i++){intu,v;cin>>u>>v;add(u,v);// 添加无向边add(v,u);}// 从任意一个黑色节点开始DFSfor(inti=1;i<=n;i++){if(a[i]==1)// 找到第一个黑色节点{dfs(i,0);// 从该节点开始DFS,父节点为0break;}}// 输出答案cout<<ans<<endl;return0;}

【运行结果】

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

C#学习路径与应用领域全方位指南

C#学习路径与应用领域全方位指南 C#作为微软开发的现代编程语言&#xff0c;凭借其简洁的语法、强大的类型系统和广泛的生态系统&#xff0c;已成为全栈开发的理想选择。学习C#的最佳路径应当遵循"环境搭建-基础语法-面向对象编程-高级特性-实战项目-设计模式与架构-开源贡…

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

2025最新!9款AI论文平台测评:本科生毕业论文写作全攻略

2025最新&#xff01;9款AI论文平台测评&#xff1a;本科生毕业论文写作全攻略 2025年AI论文平台测评&#xff1a;为何需要一份权威榜单&#xff1f; 随着人工智能技术的不断进步&#xff0c;越来越多的本科生开始借助AI工具辅助毕业论文写作。然而&#xff0c;面对市场上种类繁…

作者头像 李华
网站建设 2026/4/16 21:51:47

Product Hunt 每日热榜 | 2025-12-24

1. Super Agents by ClickUp 标语&#xff1a;标签、消息&#xff0c; 在日常工作流程中管理人工智能助手。 介绍&#xff1a;超级代理是你可以在几秒钟内启动的AI助手&#xff0c;它们能够在ClickUp中执行整个工作流程。任何人都可以创建超级代理&#xff0c;并可以提及、分…

作者头像 李华
网站建设 2026/4/12 22:48:27

2025必备10个降AI率工具测评榜单

2025必备10个降AI率工具测评榜单 2025年降AI率工具测评&#xff1a;为何需要专业榜单&#xff1f; 随着高校和科研机构对AIGC内容的识别能力不断提升&#xff0c;论文、报告甚至日常作业中的AI生成痕迹越来越容易被检测出来。对于本科生而言&#xff0c;如何在保证内容原创性的…

作者头像 李华
网站建设 2026/4/7 21:36:07

Open-AutoGLM模型获取秘籍:3种高效下载方式,第2种最快仅需10分钟

第一章&#xff1a;开源模型Open-AutoGLM下载获取模型源码与依赖环境 Open-AutoGLM 是一个面向自动化图形语言建模的开源项目&#xff0c;其代码托管于主流开源平台。用户可通过 Git 工具克隆官方仓库&#xff0c;快速部署本地开发环境。安装 Git 与 Python 3.9 运行时环境执行…

作者头像 李华