#Lutece0263. Slim Span
Slim Span
Migrated from Lutece 263 Slim Span
All parts of this problem, including description, images, samples, data and checker, might be broken. If you find bugs in this problem, please contact the admins.
Description
Given an undirected weighted graph , you should find one of spanning trees specified as follows.
The graph is an ordered pair , where is a set of vertices {} and is a set of undirected edges {}. Each edge has its weight .
A spanning tree is a tree (a connected subgraph without cycles) which connects all the vertices with edges. The slimness of a spanning tree is defined as the difference between the largest weight and the smallest weight among the edges of .
Figure 5: A graph G and the weights of the edges
For example, a graph in Figure 5(a) has four vertices {} and five undirected edges {}. The weights of the edges are $w(e_1) = 3, w(e_2) = 5, w(e_3) = 6, w(e_4) = 6, w(e_5) = 7$ as shown in Figure .
Figure 6: Examples of the spanning trees of G
There are several spanning trees for . Four of them are depicted in Figure . The spanning tree in Figure has three edges whose weights are and . The largest weight is and the smallest weight is so that the slimness of the tree is . The slimnesses of spanning trees and shown in Figure and are and , respectively. You can easily see the slimness of any other spanning tree is greater than or equal to , thus the spanning tree in Figure is one of the slimmest spanning trees whose slimness is .
Your job is to write a program that computes the smallest slimness.
Input
The input consists of multiple datasets, followed by a line containing two zeros separated by a space. Each dataset has the following format.
Every input item in a dataset is a non-negative integer. Items in a line are separated by a space. is the number of the vertices and m the number of the edges. You can assume and . and are positive integers less than or equal to , which represent the two vertices and connected by the _th edge . is a positive integer less than or equal to , which indicates the weight of . You can assume that the graph is simple, that is, there are no self-loops (that connect the same vertex) nor parallel edges (that are two or more edges whose both ends are the same two vertices).
Output
For each dataset, if the graph has spanning trees, the smallest slimness among them should be printed. Otherwise, -1
should be printed. An output should not contain extra characters.
Samples
4 5
1 2 3
1 3 5
1 4 6
2 4 6
3 4 7
4 6
1 2 10
1 3 100
1 4 90
2 3 20
2 4 80
3 4 40
2 1
1 2 1
3 0
3 1
1 2 1
3 3
1 2 2
2 3 5
1 3 6
5 10
1 2 110
1 3 120
1 4 130
1 5 120
2 3 110
2 4 120
2 5 130
3 4 120
3 5 110
4 5 120
5 10
1 2 9384
1 3 887
1 4 2778
1 5 6916
2 3 7794
2 4 8336
2 5 5387
3 4 493
3 5 6650
4 5 1422
5 8
1 2 1
2 3 100
3 4 100
4 5 100
1 5 50
2 5 50
3 5 50
4 1 150
0 0
1
20
0
-1
-1
1
0
1686
50
Resources
Japan 2007