#GESP1024. [GESP202406六级] 二叉树
[GESP202406六级] 二叉树
题目背景
2024 年 6 月 GESP C++ 六级编程第 2 题
题目描述
小杨有一棵包含 个节点的二叉树,且根节点的编号为 。这棵二叉树任意一个节点要么是白色,要么是黑色。之后 小杨会对这棵二叉树进行 次操作,每次小杨会选择一个节点,将以这个节点为根的子树内所有节点的颜色反转, 即黑色变成白色,白色变成黑色。
小杨想知道 次操作全部完成之后每个节点的颜色。
输入格式
第一行一个正整数 ,表示二叉树的节点数量。
第二行 个正整数,第 个数表示编号为 的节点的父亲节点编号,数据保证是一棵二叉 树。
第三行一个长度为 的 串,从左到右第 位如果为 ,表示编号为 的节点颜色为白色,否则为黑 色。
第四行一个正整数 ,表示操作次数。
接下来 行每行一个正整数 ,表示第 次操作选择的节点编号。
输出格式
输出一行一个长度为 的 串,表示 次操作全部完成之后每个节点的颜色。从左到右第 位如果为 ,表示编号为 的节点颜色为白色,否则为黑色。
样例
6
3 1 1 3 4
100101
3
1
3
2
010000
样例解释
第一次操作后,节点颜色为:011010
第二次操作后,节点颜色为:000000
第三次操作后,节点颜色为:010000
数据范围
子任务编号 | 数据点占比 | 特殊条件 | |
---|---|---|---|
1 | 对于所有的 , 存在节点 的父亲节点编号为 | ||
2 | |||
3 |
对于全部数据,保证有 。