Reindeer Games

 There are 

n reindeer at the North Pole, all battling for the highest spot on the "Top Reindeer" leaderboard on the front page of CodeNorses (a popular competitive reindeer gaming website). Interestingly, the "Top Reindeer" title is just a measure of upvotes and has nothing to do with their skill level in the reindeer games, but they still give it the utmost importance.

Currently, the i-th reindeer has a score of ai. You would like to influence the leaderboard with some operations. In an operation, you can choose a reindeer, and either increase or decrease his score by 1 unit. Negative scores are allowed.

You have m requirements for the resulting scores. Each requirement is given by an ordered pair (u,v), meaning that after all operations, the score of reindeer u must be less than or equal to the score of reindeer v.

Your task is to perform the minimum number of operations so that all requirements will be satisfied.

Input

The first line contains two integers n and m (2n10001m1000) — the number of reindeer and requirements, respectively.

The second line contains n integers a1,,an (1ai109), where ai is the current score of reindeer i.

The next m lines describe the requirements.

The i-th of these lines contains two integers ui and vi (1ui,vinuivi) — the two reindeer of the i-th requirement.

Output

Print n integers b1,,bn (1015bi1015), where bi is the score of the i-th reindeer after all operations.

If there are multiple solutions achieving the minimum number of operations, you may output any.

We can prove that there is always an optimal solution such that |bi|1015 for all i.

Examples
input
Copy
7 6
3 1 4 9 2 5 6
1 2
2 3
3 4
4 5
5 6
6 7
output
Copy
1 1 4 4 4 5 6 
input
Copy
4 6
6 5 8 2
3 1
4 1
3 2
1 2
2 3
3 1
output
Copy
6 6 6 2 
input
Copy
10 18
214 204 195 182 180 176 176 172 169 167
1 2
3 2
4 2
5 2
6 2
7 2
8 2
9 2
10 2
6 1
6 2
6 3
6 4
6 5
6 7
6 8
6 9
6 10
output
Copy
204 204 195 182 180 167 176 172 169 167 
Previous
Next Post »