#CF2184F. Cherry Tree
Cherry Tree
题目描述
给定一棵有 个结点的有根树 ,树的结点编号为 到 。树的根结点是 号结点。
每一片叶子 上都结有一颗樱桃。你想采集所有的樱桃,为此你需要多次执行如下操作:
你可以选择树上的任意一个结点 (可以是根或叶子),并“摇晃”它。之后,所有以 为祖先的叶子上的樱桃都会掉下来(如果 自身是叶子,则自身的樱桃会掉下)。若某片叶子的樱桃被摇落过多次,树就会损坏,因此要避免这种情况。
据传樱桃园的古老传说,你摇晃的结点数必须是 的倍数。
你能否用这种方式采集所有的樱桃?
一棵有 个结点的树是一个含 个结点、 条边的无向连通图。有根树是指定一个特殊结点为根的树。
叶子是没有子结点的结点。
结点 的后代是所有路径从根到 ,且路径上必经 的所有结点 。
输入格式
每组测试数据包含若干个测试用例。第一行为单个整数 ,表示测试用例的组数。以下为各组测试用例的数据。
每组数据的第一行为一个整数 ()。
随后 行,每行两个整数 与 (),表示一条树上的边,连接结点 和 。
保证每组数据的图都是一棵树。
保证所有测试用例中 的总和不超过 。
输出格式
对于每组测试数据,若可以采集所有樱桃,则在单独一行输出 “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
样例说明
在第一个测试用例中,你可以摇晃结点 。
在第二个测试用例中,唯一能摇晃的结点数量是 的倍数时,只能摇晃所有结点,但这样会让树损坏,所以不允许。
在第三个测试用例中,你可以例如摇晃结点 。
由 ChatGPT 5 翻译
来源
Codeforces 2184F,英文题名 Cherry Tree。