The government of a distant country is cutting as much as possible. Now they have noticed that, often, there is more than one path that goes from one town to another town (either a direct road, or a sequence of roads passing through other intermediate towns). Since every road has some maintenance cost, the government has decided to eliminate several roads to save as much as possible, but keeping the road system connected. Can you calculate the maximum savings?

Input

Input consists of several cases.
Every case begins with the number of towns (vertices) n
and the number of roads (edges) m.
Follow m triples x y c,
indicating that the maintenance cost of the road between x and y is c.
Towns are numbered from 0 to n − 1.
Assume 1 ≤ n ≤ 10^{4},
n − 1 ≤ m ≤ 10 n,
and 1 ≤ c ≤ 10^{4}.
There may be more than one road between two towns,
and even roads with x = y.
Every given graph is connected.

Output

For every case, print the maximum savings achiving that there is exactly one path between every pair of towns.

Public test cases

**Input**

3 2 0 2 10 2 1 30 3 3 0 2 10 2 1 30 1 0 20 1 0 5 9 1 0 40 0 3 60 1 2 20 2 1 10 1 4 30 4 4 20 2 1 70 3 1 30 4 2 20

**Output**

0 30 0 200

Information

- Author
- Salvador Roura
- Language
- English
- Translator
- Salvador Roura
- Original language
- Catalan
- Other languages
- Catalan
- Official solutions
- C++ Python
- User solutions
- C++