#D1902. Paired Payment
Paired Payment
Paired Payment
There are n cities and m bidirectional roads in the country. The roads in the country form an undirected weighted graph. The graph is not guaranteed to be connected. Each road has it's own parameter w. You can travel through the roads, but the government made a new law: you can only go through two roads at a time (go from city a to city b and then from city b to city c) and you will have to pay (w_{ab} + w_{bc})^2 money to go through those roads. Find out whether it is possible to travel from city 1 to every other city t and what's the minimum amount of money you need to get from 1 to t.
Input
First line contains two integers n, m (2 ≤ n ≤ 10^5, 1 ≤ m ≤ min((n ⋅ (n - 1))/(2), 2 ⋅ 10^5)).
Next m lines each contain three integers v_i, u_i, w_i (1 ≤ v_i, u_i ≤ n, 1 ≤ w_i ≤ 50, u_i ≠ v_i). It's guaranteed that there are no multiple edges, i.e. for any edge (u_i, v_i) there are no other edges (u_i, v_i) or (v_i, u_i).
Output
For every city t print one integer. If there is no correct path between 1 and t output -1. Otherwise print out the minimum amount of money needed to travel from 1 to t.
Examples
Input
5 6 1 2 3 2 3 4 3 4 5 4 5 6 1 5 1 2 4 2
Output
0 98 49 25 114
Input
3 2 1 2 1 2 3 2
Output
0 -1 9
Note
The graph in the first example looks like this.
In the second example the path from 1 to 3 goes through 2, so the resulting payment is (1 + 2)^2 = 9.
inputFormat
Input
First line contains two integers n, m (2 ≤ n ≤ 10^5, 1 ≤ m ≤ min((n ⋅ (n - 1))/(2), 2 ⋅ 10^5)).
Next m lines each contain three integers v_i, u_i, w_i (1 ≤ v_i, u_i ≤ n, 1 ≤ w_i ≤ 50, u_i ≠ v_i). It's guaranteed that there are no multiple edges, i.e. for any edge (u_i, v_i) there are no other edges (u_i, v_i) or (v_i, u_i).
outputFormat
Output
For every city t print one integer. If there is no correct path between 1 and t output -1. Otherwise print out the minimum amount of money needed to travel from 1 to t.
Examples
Input
5 6 1 2 3 2 3 4 3 4 5 4 5 6 1 5 1 2 4 2
Output
0 98 49 25 114
Input
3 2 1 2 1 2 3 2
Output
0 -1 9
Note
The graph in the first example looks like this.
In the second example the path from 1 to 3 goes through 2, so the resulting payment is (1 + 2)^2 = 9.
样例
3 2
1 2 1
2 3 2
0 -1 9
</p>