Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only ACM-ICPC mode for virtual contests.
If you've seen these problems, a virtual contest is not for you - solve these problems in the archive.
If you just want to solve some problem from a contest, a virtual contest is not for you - solve this problem in the archive.
Never use someone else's code, read the tutorials or communicate with other person during a virtual contest.

No tag edit access

F. Santa Clauses and a Soccer Championship

time limit per test

2 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputThe country Treeland consists of *n* cities connected with *n* - 1 bidirectional roads in such a way that it's possible to reach every city starting from any other city using these roads. There will be a soccer championship next year, and all participants are Santa Clauses. There are exactly 2*k* teams from 2*k* different cities.

During the first stage all teams are divided into *k* pairs. Teams of each pair play two games against each other: one in the hometown of the first team, and the other in the hometown of the other team. Thus, each of the 2*k* cities holds exactly one soccer game. However, it's not decided yet how to divide teams into pairs.

It's also necessary to choose several cities to settle players in. Organizers tend to use as few cities as possible to settle the teams.

Nobody wants to travel too much during the championship, so if a team plays in cities *u* and *v*, it wants to live in one of the cities on the shortest path between *u* and *v* (maybe, in *u* or in *v*). There is another constraint also: the teams from one pair must live in the same city.

Summarizing, the organizers want to divide 2*k* teams into pairs and settle them in the minimum possible number of cities *m* in such a way that teams from each pair live in the same city which lies between their hometowns.

Input

The first line of input contains two integers *n* and *k* (2 ≤ *n* ≤ 2·10^{5}, 2 ≤ 2*k* ≤ *n*) — the number of cities in Treeland and the number of pairs of teams, respectively.

The following *n* - 1 lines describe roads in Treeland: each of these lines contains two integers *a* and *b* (1 ≤ *a*, *b* ≤ *n*, *a* ≠ *b*) which mean that there is a road between cities *a* and *b*. It's guaranteed that there is a path between any two cities.

The last line contains 2*k* distinct integers *c*_{1}, *c*_{2}, ..., *c*_{2k} (1 ≤ *c*_{i} ≤ *n*), where *c*_{i} is the hometown of the *i*-th team. All these numbers are distinct.

Output

The first line of output must contain the only positive integer *m* which should be equal to the minimum possible number of cities the teams can be settled in.

The second line should contain *m* distinct numbers *d*_{1}, *d*_{2}, ..., *d*_{m} (1 ≤ *d*_{i} ≤ *n*) denoting the indices of the cities where the teams should be settled.

The *k* lines should follow, the *j*-th of them should contain 3 integers *u*_{j}, *v*_{j} and *x*_{j}, where *u*_{j} and *v*_{j} are the hometowns of the *j*-th pair's teams, and *x*_{j} is the city they should live in during the tournament. Each of the numbers *c*_{1}, *c*_{2}, ..., *c*_{2k} should occur in all *u*_{j}'s and *v*_{j}'s exactly once. Each of the numbers *x*_{j} should belong to {*d*_{1}, *d*_{2}, ..., *d*_{m}}.

If there are several possible answers, print any of them.

Example

Input

6 2

1 2

1 3

2 4

2 5

3 6

2 5 4 6

Output

1

2

5 4 2

6 2 2

Note

In the first test the orginizers can settle all the teams in the city number 2. The way to divide all teams into pairs is not important, since all requirements are satisfied anyway, because the city 2 lies on the shortest path between every two cities from {2, 4, 5, 6}.

Codeforces (c) Copyright 2010-2019 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Mar/19/2019 23:05:39 (d2).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|