#CF2184F. Cherry Tree

    ID: 7008 传统题 1000ms 256MiB 尝试: 1 已通过: 1 难度: 10 上传者: 标签>深度优先搜索动态规划图论CodeforcesCodeforces Round 1072(Div3)Div3FCF2184F1900

Cherry Tree

题目描述

给定一棵有 nn 个结点的有根树 ^{\text{∗}},树的结点编号为 11nn。树的根结点是 11 号结点。

每一片叶子 ^{\text{†}} 上都结有一颗樱桃。你想采集所有的樱桃,为此你需要多次执行如下操作:

你可以选择树上的任意一个结点 vv(可以是根或叶子),并“摇晃”它。之后,所有以 vv 为祖先的叶子上的樱桃都会掉下来(如果 vv 自身是叶子,则自身的樱桃会掉下)。若某片叶子的樱桃被摇落过多次,树就会损坏,因此要避免这种情况。

据传樱桃园的古老传说,你摇晃的结点数必须是 33 的倍数。

你能否用这种方式采集所有的樱桃?

^{\text{∗}} 一棵有 nn 个结点的树是一个含 nn 个结点、n1n-1 条边的无向连通图。有根树是指定一个特殊结点为根的树。

^{\text{†}} 叶子是没有子结点的结点。

^{\text{‡}} 结点 vv 的后代是所有路径从根到 uvu \neq v,且路径上必经 vv 的所有结点 uu

输入格式

每组测试数据包含若干个测试用例。第一行为单个整数 tt (1t104)(1 \le t \le 10^4),表示测试用例的组数。以下为各组测试用例的数据。

每组数据的第一行为一个整数 nn2n21052 \leq n \leq 2 \cdot 10^5)。

随后 n1n-1 行,每行两个整数 uuvv1u,vn,uv1 \leq u, v \leq n, u \neq v),表示一条树上的边,连接结点 uuvv

保证每组数据的图都是一棵树。

保证所有测试用例中 nn 的总和不超过 2×1052 \times 10^5

输出格式

对于每组测试数据,若可以采集所有樱桃,则在单独一行输出 “YES”;否则输出 “NO”。

可以以任意大小写输出答案(例如 “YeS”、“no”、“yES” 都是可接受的)。

样例

3
4
1 2
1 3
1 4
3
1 2
1 3
9
1 2
3 1
2 4
5 2
5 6
3 7
8 3
8 9
YES
NO
YES

样例说明

在第一个测试用例中,你可以摇晃结点 2,3,42, 3, 4

在第二个测试用例中,唯一能摇晃的结点数量是 33 的倍数时,只能摇晃所有结点,但这样会让树损坏,所以不允许。

在第三个测试用例中,你可以例如摇晃结点 2,7,92, 7, 9

由 ChatGPT 5 翻译

来源

Codeforces 2184F,英文题名 Cherry Tree。