CFCF2193H.Remove the Grail Tree

提高+/省选-

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

伟大的圣杯树已在王国中矗立了 315 年。它占据了大量空间,因此伊拉国王决定尽快将其移除。这棵树本质上是一个包含 nn 个顶点的无环、连通、无向图,每个顶点都有一个权值 ava_v。移除这棵树的规则如下:

  1. SvS_v 为顶点 vv 所有剩余相邻顶点的权值之和。若 vv 没有剩余相邻顶点,则 Sv=0S_v = 0。选择一个满足 ava_vSvS_v 奇偶性不同的顶点 vv(即 ava_v 为偶数且 SvS_v 为奇数,或 ava_v 为奇数且 SvS_v 为偶数);若不存在这样的顶点,则停止操作。
  2. 从树中移除顶点 vv 及其所有相连的边。

你的任务是判断是否存在一个移除序列,能将这棵圣杯树完全移除(即树中无任何顶点剩余)。若存在这样的序列,输出长度为 nn 的移除顺序序列;若有多个合法序列,输出任意一个即可。

输入格式

输入包含多组测试用例。第一行输入一个整数 tt1t1041 \le t \le 10^4),表示测试用例的数量。

每个测试用例的格式如下:

  1. 第一行输入一个整数 nn1n2×1051 \le n \le 2 \times 10^5),表示树的顶点数量。
  2. 第二行输入一个长度为 nn 的数组 aa1ai1091 \le a_i \le 10^9),依次表示每个顶点的权值。
  3. 接下来 n1n-1 行,每行输入两个整数 v,uv, u1v,un1 \le v, u \le nvuv \neq u),表示顶点 vvuu 之间有一条无向边。

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

输出格式

对于每个测试用例:

  • 若可以完全移除树,输出 "YES";否则输出 "NO"(字母大小写任意)。
  • 若答案为 "YES",额外输出一行包含 nn 个整数的序列,表示顶点的移除顺序(任意合法序列均可)。

输入输出样例

  • 输入#1

    5
    3
    1 2 4
    1 2
    2 3
    4
    3 4 2 1
    1 2
    2 3
    3 4
    6
    9 6 5 1 7 4
    1 2
    2 3
    2 4
    3 5
    4 6
    5
    2 1 1 1 2
    2 1
    3 2
    2 4
    5 4
    5
    1 5 3 7 9
    1 2
    2 3
    3 4
    4 5

    输出#1

    NO
    YES
    2 3 1 4 
    NO
    YES
    1 5 2 3 4 
    YES
    2 4 1 5 3
首页