#5104. Problem 1. Barn Tree

0

Problem 1. Barn Tree

Problem 1. Barn Tree

USACO 2022 December Contest, Silver

Note: the time limit for this problem is 4s, two times the default. The memory limit is also twice the default.

Farmer John's farm has NN barns (2N21052 \leq N \leq 2\cdot 10^5) numbered 1N1 \dots N. There are N1N-1 roads, where each road connects two barns and it is possible to get from any barn to any other barn via some sequence of roads. Currently, the jjth barn has hjh_j hay bales (1hj1091\le h_j\le 10^9).

To please his cows, Farmer John would like to move the hay such that each barn has an equal number of bales. He can select any pair of barns connected by a road and order his farmhands to move any positive integer number of bales less than or equal to the number of bales currently at the first barn from the first barn to the second.

Please determine a sequence of orders Farmer John can issue to complete the task in the minimum possible number of orders. It is guaranteed that a sequence of orders exists.

INPUT FORMAT (input arrives from the terminal / stdin):

The first line of input contains the value of N.N.

The second line of input contains the space-separated values of hjh_j for j=1Nj = 1 \dots N.

The final N1N-1 lines of input each contain two space-separated barn numbers ui viu_i \ v_i, indicating that there is a bidirectional road connecting uiu_i and viv_i.

OUTPUT FORMAT (print output to the terminal / stdout):

Output the minimum possible number of orders, followed a sequence of orders of that length, one per line.

Each order should be formatted as three space-separated positive integers: the source barn, the destination barn, and the third describes the number of hay bales to move from the source to the destination.

If there are multiple solutions, output any.

SAMPLE INPUT:


4
2 1 4 5
1 2
2 3
2 4

SAMPLE OUTPUT:


3
3 2 1
4 2 2
2 1 1

In this example, there are a total of twelve hay bales and four barns, meaning each barn must have three hay bales at the end. The sequence of orders in the sample output can be verbally translated as below:

  1. From barn 33 to barn 22, move 11 bale.
  2. From barn 44 to barn 22, move 22 bales.
  3. From barn 22 to barn 11, move 11 bale.

SCORING: Test cases 2-8 satisfy N5000N\leq 5000Test cases 7-10 satisfy vi=ui+1v_i=u_i+1Test cases 11-16 satisfy no additional constraints

Problem credits: Aryansh Shrivastava