Clarke and MST

Accepts: 59
Submissions: 108
Time Limit: 2000/1000 MS (Java/Others)
Memory Limit: 65536/65536 K (Java/Others)
Problem Description

Clarke is a patient with multiple personality disorder. One day he turned into a learner of graph theory.
He learned some algorithms of minimum spanning tree. Then he had a good idea, he wanted to find the maximum spanning tree with bit operation AND.
A spanning tree is composed by n1n-1 edges. Each two points of nn points can reach each other. The size of a spanning tree is generated by bit operation AND with values of n1n-1 edges.
Now he wants to figure out the maximum spanning tree.

Input

The first line contains an integer T(1T5)T(1 \le T \le 5), the number of test cases.
For each test case, the first line contains two integers n,m(2n300000,1m300000)n, m(2 \le n \le 300000, 1 \le m \le 300000), denoting the number of points and the number of edge respectively.
Then mm lines followed, each line contains three integers x,y,w(1x,yn,0w109)x, y, w(1 \le x, y \le n, 0 \le w \le 10^9), denoting an edge between x,yx, y with value ww. The number of test case with n,m>100000n, m > 100000 will not exceed 1.

Output

For each test case, print a line contained an integer represented the answer. If there is no any spanning tree, print 0.

Sample Input
1
4 5
1 2 5
1 3 3
1 4 2
2 3 1
3 4 7
Sample Output
1