#P2445. 2445 - 传令兵

2445 - 传令兵

题目描述

A国的边境上修建了 nn 座兵营(编号为 1n1 \sim n ),某些兵营之间修建了用于传达消息的双向道路,不同的道路由于长度和平整度不同,也就可能需要不同的天数才能走完。

为方便指挥作战,A国将指挥所修建在了 11 号兵营。当指挥部下达作战指令后,指挥部就派出若干个传令兵,按照预先修好的道路,将指令传达给相邻的兵营。当一座兵营接到指令后,会按同样的方式向其他兵营传达指令,直到所有的兵营都收到作战指令。

请编程计算出,从指挥部发出作战指令到所有兵营都收到作战命令,最短需要多少天。

输入

第一行有两个整数 nnmm ,表示有 nn 个兵营和 mm 条道路。

22m+1m+1 行,每行三个整数 x,y,kx, y, k ,表示第 xx 个和第 yy 个兵营之间存在一条需要 kk 天才能走完的双向道路。

本题数据保证任意两个兵营之间最多只有一条道路。

输出

输出所有兵营接到指令的最短天数,如果由于道路的缺失,导致无论如何都不能做到所有兵营都能接到指令,请输出 1-1

样例

4 4
1 2 4
2 3 7
2 4 1
3 4 6
11

说明

数据范围

1n1001 \le n \le 1001m5001 \le m \le 500

1x,yn1 \le x,y \le n1k10001 \le k \le 1000