문제
정점이 $n$개인 트리가 주어진다. 각 정점에는 1ドル$부터 $n$까지의 번호가 붙어 있고, $i$번 정점에는 정수 $a_{i}$가 쓰여 있다. 당신은 원하는 만큼 시행을 하여 모든 $a_{i}$를 같게 만들어야 한다.
한 번의 시행에서 당신은 정점 $v$와 음이 아닌 정수 $c$를 선택한다. 그 다음 $v$를 루트로 하는 서브트리의 모든 정점 $i$에 대하여, $a_{i}$를 $a_{i}$를 $a_{i} \oplus c$로 바꾼다. $v$를 루트로 하는 서브트리의 크기를 $s$라 할 때, 이 시행의 비용은 $s \cdot c$이다. $\oplus$는 bitwise XOR을 의미한다.
$r$번 정점이 트리의 루트일 때 목표를 달성하기 위한 최소 비용을 $m_{r}$이라 하자. $m_{1}, m_{2}, \ldots, m_{n}$을 구하여라.
출력
각각의 테스트 케이스마다 $n$개의 정수 $m_1, m_2, \ldots, m_n$을 공백으로 구분하여 출력한다.
노트
첫 번째 테스트 케이스에서, 다음 방법으로 목표를 달성할 수 있다.
- 첫 번째 시행에서 $v=2,ドル $c=1$을 선택한다. 시행 후 $a=[3, 3, 0, 1]$이 된다. 이 시행의 비용은 3ドル$이다.
- 두 번째 시행에서 $v=3,ドル $c=3$을 선택한다. 시행 후 $a=[3, 3, 3, 1]$이 된다. 이 시행의 비용은 3ドル$이다.
- 세 번째 시행에서 $v=4,ドル $c=2$를 선택한다. 시행 후 $a=[3, 3, 3, 3]$이 된다. 이 시행의 비용은 2ドル$이다.
이 과정의 총 비용은 3ドル+3+2=8$이다. 8ドル$ 미만의 비용으로 목표를 달성하는 방법이 없음을 증명할 수 있다.
$m_{2},ドル $m_{3},ドル $m_{4}$도 마찬가지로 찾을 수 있다.
두 번째 테스트 케이스에서, 정점이 하나이므로 목표가 이미 달성되었다.
[{"problem_id":"30239","problem_lang":"0","title":"\ud2b8\ub9ac\uc640 XOR","description":"<p>\uc815\uc810\uc774 $n$\uac1c\uc778 \ud2b8\ub9ac\uac00 \uc8fc\uc5b4\uc9c4\ub2e4. \uac01 \uc815\uc810\uc5d0\ub294 $1$\ubd80\ud130 $n$\uae4c\uc9c0\uc758 \ubc88\ud638\uac00 \ubd99\uc5b4 \uc788\uace0, $i$\ubc88 \uc815\uc810\uc5d0\ub294 \uc815\uc218 $a_{i}$\uac00 \uc4f0\uc5ec \uc788\ub2e4. \ub2f9\uc2e0\uc740 \uc6d0\ud558\ub294 \ub9cc\ud07c \uc2dc\ud589\uc744 \ud558\uc5ec \ubaa8\ub4e0 $a_{i}$\ub97c \uac19\uac8c \ub9cc\ub4e4\uc5b4\uc57c \ud55c\ub2e4.<\/p>\r\n\r\n<p>\ud55c \ubc88\uc758 \uc2dc\ud589\uc5d0\uc11c \ub2f9\uc2e0\uc740 \uc815\uc810 $v$\uc640 \uc74c\uc774 \uc544\ub2cc \uc815\uc218 $c$\ub97c \uc120\ud0dd\ud55c\ub2e4. \uadf8 \ub2e4\uc74c $v$\ub97c \ub8e8\ud2b8\ub85c \ud558\ub294 \uc11c\ube0c\ud2b8\ub9ac\uc758 \ubaa8\ub4e0 \uc815\uc810 $i$\uc5d0 \ub300\ud558\uc5ec, $a_{i}$\ub97c $a_{i}$\ub97c $a_{i} \\oplus c$\ub85c \ubc14\uafbc\ub2e4. $v$\ub97c \ub8e8\ud2b8\ub85c \ud558\ub294 \uc11c\ube0c\ud2b8\ub9ac\uc758 \ud06c\uae30\ub97c $s$\ub77c \ud560 \ub54c, \uc774 \uc2dc\ud589\uc758 \ube44\uc6a9\uc740 $s \\cdot c$\uc774\ub2e4. $\\oplus$\ub294 <a href=\"https:\/\/en.wikipedia.org\/wiki\/Bitwise_operation#XOR\">bitwise XOR<\/a>\uc744 \uc758\ubbf8\ud55c\ub2e4.<\/p>\r\n\r\n<p>$r$\ubc88 \uc815\uc810\uc774 \ud2b8\ub9ac\uc758 \ub8e8\ud2b8\uc77c \ub54c \ubaa9\ud45c\ub97c \ub2ec\uc131\ud558\uae30 \uc704\ud55c \ucd5c\uc18c \ube44\uc6a9\uc744 $m_{r}$\uc774\ub77c \ud558\uc790. $m_{1}, m_{2}, \\ldots, m_{n}$\uc744 \uad6c\ud558\uc5ec\ub77c.<\/p>\r\n","input":"<p>\uac01 \uc785\ub825\uc740 \uc5ec\ub7ec \uac1c\uc758 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\ub85c \uc774\ub8e8\uc5b4\uc838 \uc788\ub2e4. \uccab \ubc88\uc9f8 \uc904\uc5d0 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc758 \uac1c\uc218 $t$\uac00 \uc8fc\uc5b4\uc9c4\ub2e4($1 \\le t \\le 10^{4}$). \ub2e4\uc74c \uc904\ubd80\ud130 \uac01\uac01\uc758 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uac00 \uc8fc\uc5b4\uc9c4\ub2e4.<\/p>\r\n\r\n<p>\uac01\uac01\uc758 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc758 \uccab \ubc88\uc9f8 \uc904\uc5d0 \uc815\uc218 $n$\uc774 \uc8fc\uc5b4\uc9c4\ub2e4 ($1 \\le n \\le 2 \\cdot 10^{5}$).<\/p>\r\n\r\n<p>\ub450 \ubc88\uc9f8 \uc904\uc5d0 $n$\uac1c\uc758 \uc815\uc218 $a_1, a_2, \\ldots, a_n$\uac00 \uc8fc\uc5b4\uc9c4\ub2e4 ($0 \\le a_i &lt; 2^{20}$).<\/p>\r\n\r\n<p>\ub2e4\uc74c $n-1$\uac1c\uc758 \uc904\uc5d0 \ud2b8\ub9ac\uc758 \uac04\uc120\uc774 \uc787\ub294 \uc815\uc810\uc758 \ubc88\ud638\ub97c \ub098\ud0c0\ub0b4\ub294 \ub450 \uc815\uc218 $u$\uc640 $v$\uac00 \uacf5\ubc31\uc73c\ub85c \uad6c\ubd84\ub418\uc5b4 \uc8fc\uc5b4\uc9c4\ub2e4 ($1 \\le u, v \\le n$),<\/p>\r\n\r\n<p>\uc8fc\uc5b4\uc9c4 \uac04\uc120\uc774 \ud2b8\ub9ac\ub97c \uc774\ub8f8\uc774 \ubcf4\uc7a5\ub41c\ub2e4.<\/p>\r\n\r\n<p>\ubaa8\ub4e0 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc5d0\uc11c $n$\uc758 \ucd1d\ud569\uc740 $2 \\cdot 10^{5}$\ub97c \ub118\uc9c0 \uc54a\ub294\ub2e4.<\/p>\r\n","output":"<p>\uac01\uac01\uc758 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\ub9c8\ub2e4 $n$\uac1c\uc758 \uc815\uc218 $m_1, m_2, \\ldots, m_n$\uc744 \uacf5\ubc31\uc73c\ub85c \uad6c\ubd84\ud558\uc5ec \ucd9c\ub825\ud55c\ub2e4.<\/p>\r\n","hint":"<p>\uccab \ubc88\uc9f8 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc5d0\uc11c, \ub2e4\uc74c \ubc29\ubc95\uc73c\ub85c \ubaa9\ud45c\ub97c \ub2ec\uc131\ud560 \uc218 \uc788\ub2e4.<\/p>\r\n\r\n<ol>\r\n\t<li>\uccab \ubc88\uc9f8 \uc2dc\ud589\uc5d0\uc11c $v=2$, $c=1$\uc744 \uc120\ud0dd\ud55c\ub2e4. \uc2dc\ud589 \ud6c4 $a=[3, 3, 0, 1]$\uc774 \ub41c\ub2e4. \uc774 \uc2dc\ud589\uc758 \ube44\uc6a9\uc740 $3$\uc774\ub2e4.<\/li>\r\n\t<li>\ub450 \ubc88\uc9f8 \uc2dc\ud589\uc5d0\uc11c $v=3$, $c=3$\uc744 \uc120\ud0dd\ud55c\ub2e4. \uc2dc\ud589 \ud6c4 $a=[3, 3, 3, 1]$\uc774 \ub41c\ub2e4. \uc774 \uc2dc\ud589\uc758 \ube44\uc6a9\uc740 $3$\uc774\ub2e4.<\/li>\r\n\t<li>\uc138 \ubc88\uc9f8 \uc2dc\ud589\uc5d0\uc11c $v=4$, $c=2$\ub97c \uc120\ud0dd\ud55c\ub2e4. \uc2dc\ud589 \ud6c4 $a=[3, 3, 3, 3]$\uc774 \ub41c\ub2e4. \uc774 \uc2dc\ud589\uc758 \ube44\uc6a9\uc740 $2$\uc774\ub2e4.<\/li>\r\n<\/ol>\r\n\r\n<p>\uc774 \uacfc\uc815\uc758 \ucd1d \ube44\uc6a9\uc740 $3+3+2=8$\uc774\ub2e4. $8$ \ubbf8\ub9cc\uc758 \ube44\uc6a9\uc73c\ub85c \ubaa9\ud45c\ub97c \ub2ec\uc131\ud558\ub294 \ubc29\ubc95\uc774 \uc5c6\uc74c\uc744 \uc99d\uba85\ud560 \uc218 \uc788\ub2e4.<\/p>\r\n\r\n<p>$m_{2}$, $m_{3}$, $m_{4}$\ub3c4 \ub9c8\ucc2c\uac00\uc9c0\ub85c \ucc3e\uc744 \uc218 \uc788\ub2e4.<\/p>\r\n\r\n<p>\ub450 \ubc88\uc9f8 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc5d0\uc11c, \uc815\uc810\uc774 \ud558\ub098\uc774\ubbc0\ub85c \ubaa9\ud45c\uac00 \uc774\ubbf8 \ub2ec\uc131\ub418\uc5c8\ub2e4.<\/p>\r\n","original":"1","html_title":"0","problem_lang_tcode":"Korean"},{"problem_id":"30239","problem_lang":"1","title":"Tree XOR","description":"<p>You are given a tree with $n$ vertices labeled from $1$ to $n$. An integer $a_{i}$ is written on vertex $i$ for $i = 1, 2, \\ldots, n$. You want to make all $a_{i}$ equal by performing some (possibly, zero) spells.<\/p>\r\n\r\n<p>Suppose you root the tree at some vertex. On each spell, you can select any vertex $v$ and any non-negative integer $c$. Then for all vertices $i$ in the subtree$^{\\dagger}$ of $v$, replace $a_{i}$ with $a_{i} \\oplus c$. The cost of this spell is $s \\cdot c$, where $s$ is the number of vertices in the subtree. Here $\\oplus$ denotes the <a href=\"https:\/\/en.wikipedia.org\/wiki\/Bitwise_operation#XOR\">bitwise XOR operation<\/a>.<\/p>\r\n\r\n<p>Let $m_r$ be the minimum possible total cost required to make all $a_i$ equal, if vertex $r$ is chosen as the root of the tree. Find $m_{1}, m_{2}, \\ldots, m_{n}$.<\/p>\r\n\r\n<p>$^{\\dagger}$ Suppose vertex $r$ is chosen as the root of the tree. Then vertex $i$ belongs to the subtree of $v$ if the simple path from $i$ to $r$ contains $v$.<\/p>\r\n","input":"<p>Each test contains multiple test cases. The first line contains the number of test cases $t$ ($1 \\le t \\le 10^{4}$). The description of the test cases follows.<\/p>\r\n\r\n<p>The first line of each test case contains a single integer $n$ ($1 \\le n \\le 2 \\cdot 10^{5}$).<\/p>\r\n\r\n<p>The second line of each test case contains $n$ integers $a_1, a_2, \\ldots, a_n$ ($0 \\le a_i &lt; 2^{20}$).<\/p>\r\n\r\n<p>Each of the next $n-1$ lines contains two integers $u$ and $v$ ($1 \\le u, v \\le n$), denoting that there is an edge connecting two vertices $u$ and $v$.<\/p>\r\n\r\n<p>It is guaranteed that the given edges form a tree.<\/p>\r\n\r\n<p>It is guaranteed that the sum of $n$ over all test cases does not exceed $2 \\cdot 10^{5}$.<\/p>\r\n","output":"<p>For each test case, print $m_1, m_2, \\ldots, m_n$ on a new line.<\/p>\r\n","hint":"<p>In the first test case, to find $m_1$ we root the tree at vertex $1$.<\/p>\r\n\r\n<ol>\r\n\t<li>In the first spell, choose $v=2$ and $c=1$. After performing the spell, $a$ will become $[3, 3, 0, 1]$. The cost of this spell is $3$.<\/li>\r\n\t<li>In the second spell, choose $v=3$ and $c=3$. After performing the spell, $a$ will become $[3, 3, 3, 1]$. The cost of this spell is $3$.<\/li>\r\n\t<li>In the third spell, choose $v=4$ and $c=2$. After performing the spell, $a$ will become $[3, 3, 3, 3]$. The cost of this spell is $2$.<\/li>\r\n<\/ol>\r\n\r\n<p>Now all the values in array $a$ are equal, and the total cost is $3 + 3 + 2 = 8$.<\/p>\r\n\r\n<p>The values $m_2$, $m_3$, $m_4$ can be found analogously.<\/p>\r\n\r\n<p>In the second test case, the goal is already achieved because there is only one vertex.<\/p>\r\n","original":"0","html_title":"0","problem_lang_tcode":"English"}]