Codeforces Round 906 (Div. 1) |
---|
Закончено |
У Дореми есть корневое дерево размера $$$n$$$, корнем которого является вершина $$$r$$$. Изначально на вершине $$$i$$$ записано число $$$w_i$$$. Дореми может использовать свою силу, чтобы выполнить данную операцию не более $$$k$$$ раз:
Дореми хочет узнать, каким будет лексикографически минимальный$$$^\dagger$$$ массив $$$w$$$ после выполнения всех операций. Можете ли вы ей помочь?
Если ответов несколько, вы можете вывести любой из них.
$$$^\dagger$$$ Для массивов $$$a$$$ и $$$b$$$ длины $$$n$$$, $$$a$$$ лексикографически меньше $$$b$$$ тогда и только тогда, когда существует индекс $$$i$$$ ($$$1 \leq i \le n$$$) такой, что $$$a_i < b_i$$$ и для всех индексов $$$j$$$ таких, что $$$j<i$$$, выполняется условие $$$a_j=b_j$$$.
Входные данные состоят из нескольких наборов исходных данных. Первая строка содержит одно целое число $$$t$$$ ($$$1\le t\le 10^4$$$) — количество наборов входных данных. Далее следует описание наборов входных данных.
Первая строка содержит три целых числа $$$n$$$, $$$r$$$, $$$k$$$ ($$$2 \le n \le 5000$$$, $$$1 \le r \le n$$$, $$$0 \le k \le \min(500,n)$$$).
Вторая строка содержит $$$n$$$ целых чисел $$$w_1,w_2,\ldots,w_n$$$ ($$$1 \le w_i \le 10^6$$$).
Каждая из следующих $$$n-1$$$ строк содержит два целых числа $$$u_i$$$, $$$v_i$$$ ($$$1 \leq u_i, v_i \leq n$$$), представляющих собой ребро между $$$u_i$$$ и $$$v_i$$$.
Гарантируется, что заданные ребра образуют дерево.
Гарантируется, что сумма $$$n$$$ по всем наборам входных данных не превышает $$$50\,000$$$.
Для каждого набора входных данных в первой строке выведите одно целое число $$$cnt$$$ ($$$0 \le cnt \le k$$$) — количество выполняемых операций.
Затем во второй строке выведите $$$cnt$$$ целых чисел $$$p_1,p_2,\ldots,p_{cnt}$$$ — $$$x$$$ выбирается равным $$$p_i$$$ для $$$i$$$-й операции.
Если ответов несколько, то можно вывести любой из них.
46 1 11 9 2 6 1 81 21 32 43 63 57 7 23 1 3 3 1 1 27 17 27 41 52 34 66 5 13 1 3 1 1 35 35 15 63 41 23 2 11000000 999999 9999972 11 3
1 2 2 1 4 1 5 1 1
В первом наборе входных данных:
Изначально $$$w=[1,9,2,6,1,8]$$$. Можно выбрать некоторую вершину $$$x$$$ для выполнения не более одной операции.
$$$w$$$ является лексикографически наименьшим, если $$$x=2$$$.
Название |
---|