Codeforces celebrates 10 years! We are pleased to announce the crowdfunding-campaign. Congratulate us by the link https://codeforces.com/10years.
×

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.

No tag edit access

D. Power Tree

time limit per test

2 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputYou are given a rooted tree with $$$n$$$ vertices, the root of the tree is the vertex $$$1$$$. Each vertex has some non-negative price. A leaf of the tree is a non-root vertex that has degree $$$1$$$.

Arkady and Vasily play a strange game on the tree. The game consists of three stages. On the first stage Arkady buys some non-empty set of vertices of the tree. On the second stage Vasily puts some integers into all leaves of the tree. On the third stage Arkady can perform several (possibly none) operations of the following kind: choose some vertex $$$v$$$ he bought on the first stage and some integer $$$x$$$, and then add $$$x$$$ to all integers in the leaves in the subtree of $$$v$$$. The integer $$$x$$$ can be positive, negative of zero.

A leaf $$$a$$$ is in the subtree of a vertex $$$b$$$ if and only if the simple path between $$$a$$$ and the root goes through $$$b$$$.

Arkady's task is to make all integers in the leaves equal to zero. What is the minimum total cost $$$s$$$ he has to pay on the first stage to guarantee his own win independently of the integers Vasily puts on the second stage? Also, we ask you to find all such vertices that there is an optimal (i.e. with cost $$$s$$$) set of vertices containing this one such that Arkady can guarantee his own win buying this set on the first stage.

Input

The first line contains a single integer $$$n$$$ ($$$2 \le n \le 200\,000$$$) — the number of vertices in the tree.

The second line contains $$$n$$$ integers $$$c_1, c_2, \ldots, c_n$$$ ($$$0 \le c_i \le 10^9$$$), where $$$c_i$$$ is the price of the $$$i$$$-th vertex.

Each of the next $$$n - 1$$$ lines contains two integers $$$a$$$ and $$$b$$$ ($$$1 \le a, b \le n$$$), denoting an edge of the tree.

Output

In the first line print two integers: the minimum possible cost $$$s$$$ Arkady has to pay to guarantee his own win, and the number of vertices $$$k$$$ that belong to at least one optimal set.

In the second line print $$$k$$$ distinct integers in increasing order the indices of the vertices that belong to at least one optimal set.

Examples

Input

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

Output

4 3 2 4 5

Input

3 1 1 1 1 2 1 3

Output

2 3 1 2 3

Note

In the second example all sets of two vertices are optimal. So, each vertex is in at least one optimal set.

Codeforces (c) Copyright 2010-2020 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Feb/22/2020 14:06:14 (f2).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|