CF1675F.Vlad and Unfinished Business

普及/提高-

通过率:0%

AC君温馨提醒

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

题目描述

Vlad and Nastya live in a city consisting of nn houses and n1n-1 road. From each house, you can get to the other by moving only along the roads. That is, the city is a tree.

Vlad lives in a house with index xx , and Nastya lives in a house with index yy . Vlad decided to visit Nastya. However, he remembered that he had postponed for later kk things that he has to do before coming to Nastya. To do the ii -th thing, he needs to come to the aia_i -th house, things can be done in any order. In 11 minute, he can walk from one house to another if they are connected by a road.

Vlad does not really like walking, so he is interested what is the minimum number of minutes he has to spend on the road to do all things and then come to Nastya. Houses a1,a2,,aka_1, a_2, \dots, a_k he can visit in any order. He can visit any house multiple times (if he wants).

输入格式

The first line of input contains an integer tt ( 1t1041 \le t \le 10^4 ) — the number of input test cases. There is an empty line before each test case.

The first line of each test case contains two integers nn and kk ( 1kn21051 \le k \le n \le 2\cdot 10^5 ) — the number of houses and things, respectively.

The second line of each test case contains two integers xx and yy ( 1x,yn1 \le x, y \le n ) — indices of the houses where Vlad and Nastya live, respectively.

The third line of each test case contains kk integers a1,a2,,aka_1, a_2, \dots, a_k ( 1ain1 \le a_i \le n ) — indices of houses Vlad need to come to do things.

The following n1n-1 lines contain description of city, each line contains two integers vjv_j and uju_j ( 1uj,vjn1 \le u_j, v_j \le n ) — indices of houses connected by road jj .

It is guaranteed that the sum of nn for all cases does not exceed 21052\cdot10^5 .

输出格式

Output tt lines, each of which contains the answer to the corresponding test case of input. As an answer output single integer — the minimum number of minutes Vlad needs on the road to do all the things and come to Nastya.

输入输出样例

  • 输入#1

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

    输出#1

    3
    7
    2

说明/提示

Tree and best path for the first test case:

12131 \rightarrow 2 \rightarrow 1 \rightarrow 3 Tree and best path for the second test case:

313525653 \rightarrow 1 \rightarrow 3 \rightarrow 5 \rightarrow 2 \rightarrow 5 \rightarrow 6 \rightarrow 5 Tree and best path for the third test case:

3523 \rightarrow 5 \rightarrow 2

首页