牧场联通性维护
题目描述
Y 同学经营着一个拥有 个牧场的农场,这些牧场通过 条双向道路相连,形成一个树状结构。每条原始道路的长度均为 单位。Y 同学保证,最初从任何一个牧场出发,都可以通过这些道路到达其他任意牧场。
尽管农场目前是连通的,但 Y 同学担心某条原始道路可能会因为维护而失效。如果某条原始道路被阻断,农场将会分裂成两个不相交的连通块。为了应对这种情况,Y 同学预先规划了 条额外的双向备份道路。每条备份道路连接两个牧场 和 ,其权值为 。
Y 同学希望对于每一条原始道路,计算出:如果该道路被阻断,为了使农场重新恢复连通,所能选择的权值最小的备份道路的权值是多少。
输入格式
第一行包含两个正整数 和 。
接下来的 行,每行包含两个正整数 和 (,),表示农场中一条原始道路连接的两个牧场编号。原始道路按照输入顺序从 到 编号。
接下来的 行,每行包含三个正整数 和 (,),表示一条连接 和 的备份道路,其权值为 。
输出格式
输出 行,每行包含一个整数。第 行的整数表示第 条原始道路被阻断时,能够重新连接农场的最短备份道路的权值。如果不存在任何备份道路能够修复连通性,请输出 。
样例
样例输入 #1
6 3
1 2
1 3
4 1
4 5
6 5
2 3 7
3 6 8
6 4 5
样例输出 #1
7
7
8
5
5
数据范围与约定
对于 100% 的数据,保证 ,,。
| 子任务编号 | 分值 | 特殊性质 | |
|---|---|---|---|
| 1 | 30 | 无 | |
| 2 | A | ||
| 3 | 20 | B | |
| 4 | 无 |
特殊性质 A:保证给定的原始道路构成的树是一条链。 特殊性质 B:保证所有备份道路的权值 均相等。
京公网安备11010802045784号