Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only 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.

dp

graphs

trees

*2700

No tag edit access

The problem statement has recently been changed. View the changes.

×
E. Policeman and a Tree

time limit per test

2 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputYou are given a tree (a connected non-oriented graph without cycles) with vertices numbered from 1 to *n*, and the length of the *i*-th edge is *w*_{i}. In the vertex *s* there is a policeman, in the vertices *x*_{1}, *x*_{2}, ..., *x*_{m} (*x*_{j} ≠ *s*) *m* criminals are located.

The policeman can walk along the edges with speed 1, the criminals can move with arbitrary large speed. If a criminal at some moment is at the same point as the policeman, he instantly gets caught by the policeman. Determine the time needed for the policeman to catch all criminals, assuming everybody behaves optimally (i.e. the criminals maximize that time, the policeman minimizes that time). Everybody knows positions of everybody else at any moment of time.

Input

The first line contains single integer *n* (1 ≤ *n* ≤ 50) — the number of vertices in the tree. The next *n* - 1 lines contain three integers each: *u*_{i}, *v*_{i}, *w*_{i} (1 ≤ *u*_{i}, *v*_{i} ≤ *n*, 1 ≤ *w*_{i} ≤ 50) denoting edges and their lengths. It is guaranteed that the given graph is a tree.

The next line contains single integer *s* (1 ≤ *s* ≤ *n*) — the number of vertex where the policeman starts.

The next line contains single integer *m* (1 ≤ *m* ≤ 50) — the number of criminals. The next line contains *m* integers *x*_{1}, *x*_{2}, ..., *x*_{m} (1 ≤ *x*_{j} ≤ *n*, *x*_{j} ≠ *s*) — the number of vertices where the criminals are located. *x*_{j} are not necessarily distinct.

Output

If the policeman can't catch criminals, print single line "Terrorists win" (without quotes).

Otherwise, print single integer — the time needed to catch all criminals.

Examples

Input

4

1 2 2

1 3 1

1 4 1

2

4

3 1 4 1

Output

8

Input

6

1 2 3

2 3 5

3 4 1

3 5 4

2 6 3

2

3

1 3 5

Output

21

Note

In the first example one of the optimal scenarios is the following. The criminal number 2 moves to vertex 3, the criminal 4 — to vertex 4. The policeman goes to vertex 4 and catches two criminals. After that the criminal number 1 moves to the vertex 2. The policeman goes to vertex 3 and catches criminal 2, then goes to the vertex 2 and catches the remaining criminal.

Codeforces (c) Copyright 2010-2023 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Dec/10/2023 23:43:08 (h1).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|