#ATarc143e. [ARC143E] Reversi

[ARC143E] Reversi

题目描述

有一棵包含 NN 个顶点的树。每个顶点编号为 11NN,第 ii 条边连接顶点 AiA_i 和顶点 BiB_i。此外,每个顶点上都放置有一个“黑白棋”的棋子。每个顶点上的棋子的状态由字符串 SS 给出,SS 的第 ii 个字符为 B 时,表示顶点 ii 上的棋子正面为黑色;为 W 时,表示正面为白色。

请判断是否可以通过以下操作恰好 NN 次,将所有顶点上的棋子全部移除。如果可以,请在所有可能的选择顶点顺序 P1,P2,,PNP_1,P_2,\ldots,P_N 中,输出字典序最小的一个。

  • 每次操作可以选择一个正面为白色的棋子所在的顶点,将该顶点上的棋子移除。然后,将与该顶点相邻的所有顶点上的棋子翻面。

关于“黑白棋”的棋子:棋子一面为黑色,一面为白色,翻面后正反面颜色互换。

关于数列的字典序:给定两个不同的数列 SSTT,判断大小的算法如下:

SS 的第 ii 个元素为 SiS_i。若 SS 字典序小于 TT,记作 S<TS < T,大于则记作 S>TS > T

  1. SSTT 中较短的长度为 LL,依次比较 i=1,2,,Li=1,2,\dots,LSiS_iTiT_i 是否相等。
  2. 若存在 SiTiS_i \neq T_i,取最小的此类 iijj,比较 SjS_jTjT_j,若 Sj<TjS_j < T_j,则 S<TS < T,否则 S>TS > T,算法结束。
  3. 若所有 ii 都有 Si=TiS_i = T_i,则比较长度,短的字典序更小。

输入格式

输入以如下格式从标准输入读入:

NN
A1A_1 B1B_1
\vdots
AN1A_{N-1} BN1B_{N-1}
SS

输出格式

若目标无法达成,输出 -1。若可以达成,输出一行:

P1P_1 P2P_2 \cdots PNP_N

样例 1

输入

4
1 2
2 3
3 4
WBWW

输出

1 2 4 3

样例 2

输入

4
1 2
2 3
3 4
BBBB

输出

-1

说明/提示

数据范围

  • 1N2×1051 \leq N \leq 2 \times 10^5
  • 1Ai,BiN1 \leq A_i, B_i \leq N
  • 给定的图为一棵树。
  • SS 是仅由 BW 组成的长度为 NN 的字符串。

样例解释 2

在这种情况下,无法进行任何一次操作。

由 ChatGPT 4.1 翻译