시간 제한메모리 제한제출정답맞힌 사람정답 비율
4 초 1024 MB62233.333%

문제

En ekorre bor i ett träd med $N$ noder och $N-1$ kanter. Varje kant har längd 1 och kopplar ihop två noder. I några av noderna har ekorren gömt nötter, som han nu vill samla in. Om ekorren börjar vid nod 1 (roten av trädet), vad är kortaste avståndet han behöver gå för att hämta alla nötter och återvända till nod 1? Ekorren kan bära flera nötter samtidigt.

Det är garanterat att man kan ta sig mellan alla par av noder genom att gå via en sekvens av kanter.

입력

Den första raden innehåller två heltal $N$ och $K$ ($1 \le K\le N \le 100\,000$) -- antal noder i trädet och antal noder med nötter på. Den andra raden innehåller $K$ unika heltal -- noderna där ekorren har gömt nötter. Noderna är indexerade 1 till $N$. Därefter följer $N-1$ rader. Varje rad innehåller två heltal $1 \le a,b \le N$ som betyder att det går en kant mellan nod $a$ och nod $b$.

출력

Skriv ut ett heltal -- det kortaste avståndet ekorren behöver gå för att hämta alla nötter.

예제 입력 1

5 2
4 5
1 2
2 3
2 4
1 5

예제 출력 1

6

예제 입력 2

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

예제 출력 2

12

출처

Olympiad > Swedish Olympiad in Informatics > 2021 > Final B번

  • 문제를 만든 사람: Fredrik Ekholm