#zTYSDPlydlt50x5603. 宝藏

宝藏

题目描述

参与考古挖掘的小明得到了一份藏宝图,藏宝图上标出了 nn 个深埋在地下的宝藏屋,也给出了这 nn 个宝藏屋之间可供开发的 mm 条道路和它们的长度。

小明决心亲自前往挖掘所有宝藏屋中的宝藏。

但是,每个宝藏屋距离地面都很远,也就是说,从地面打通一条到某个宝藏屋的道路是很困难的,而开发宝藏屋之间的道路则相对容易很多。

小明的决心感动了考古挖掘的赞助商,赞助商决定免费赞助他打通一条从地面到某个宝藏屋的通道,通往哪个宝藏屋则由小明来决定。

在此基础上,小明还需要考虑如何开凿宝藏屋之间的道路。

已经开凿出的道路可以任意通行不消耗代价。

每开凿出一条新道路,小明就会与考古队一起挖掘出由该条道路所能到达的宝藏屋的宝藏。

另外,小明不想开发无用道路,即两个已经被挖掘过的宝藏屋之间的道路无需再开发。

新开发一条道路的代价是:

这条道路的长度 × 从赞助商帮你打通的宝藏屋到这条道路起点的宝藏屋所经过的宝藏屋的数量(包括赞助商帮你打通的宝藏屋和这条道路起点的宝藏屋)。

请你编写程序为小明选定由赞助商打通的宝藏屋和之后开凿的道路,使得工程总代价最小,并输出这个最小值。

输入格式

第一行两个用空格分离的正整数 nn 和 mm,代表宝藏屋的个数和道路数。

接下来 mm 行,每行三个用空格分离的正整数,分别是由一条道路连接的两个宝藏屋的编号(编号为 1n1 \sim n),和这条道路的长度 vv

输出格式

输出共一行,一个正整数,表示最小的总代价。

样例

输入样例:

4 5 
1 2 1 
1 3 3 
1 4 1 
2 3 4 
3 4 1 

输出样例:

4

样例解释

n=4,m=5n=4, m=5,道路:

  • 1-2 长度 1
  • 1-3 长度 3
  • 1-4 长度 1
  • 2-3 长度 4
  • 3-4 长度 1

最优方案:

  • 选择 1 号宝藏屋作为赞助商打通的起点(深度为 0)。
  • 开发道路 1-4(长度 1),起点是 1,深度 0+1=1(经过 1 和 4? 等等,代价计算规则:从起点到道路起点的深度数,即从 1 到 1 经过 1 个宝藏屋,所以乘的系数为 1),代价 1×1=1。
  • 开发道路 4-3(长度 1),起点是 4,从 1 到 4 经过 1 和 4 共 2 个宝藏屋(深度 1? 这里深度是经过的宝藏屋数量,即从 1 到 4 是 2),代价 1×2=2。
  • 开发道路 1-2(长度 1),起点是 1,从 1 到 1 经过 1 个宝藏屋,代价 1×1=1。 总代价 1+2+1=4。

或者:选择 1 号起点,开发 1-2 (1×1=1), 1-4 (1×1=1), 4-3 (1×2=2),总 4。

数据范围

  • 1n121 \le n \le 12
  • 0m10000 \le m \le 1000
  • v5×105v \le 5 \times 10^5

时空限制

  • 时间限制:1 秒
  • 空间限制:64 MB