PivotOJ

Barn Tree

시간 제한: 4000ms메모리 제한: 1024MB출처: USACO 2022 December SilverBOJ 26972

문제

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.

입력

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 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.

힌트

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.

예제

예제 1

입력
4
2 1 4 5
1 2
2 3
2 4
출력
3
3 2 1
4 2 2
2 1 1
코드를 제출하려면 로그인하세요.