MST Company

题意翻译

求一种特殊的最小生成树。给定一个有 $n$ 个节点和 $m$ 条边的图,找出一个生成树满足从根节点 $1$ 直接连向其余节点的边要恰好是 $k$ 条,在此条件下生成树的权值和最小。不存在这样的生成树输出 `-1`。$1 \le n \le 5000, 0\le m \le 10 ^ 5, 0\le k < 5000$。 感谢 @frankchenfu 提供的翻译。

题目描述

The MST (Meaningless State Team) company won another tender for an important state reform in Berland. There are $ n $ cities in Berland, some pairs of the cities are connected by roads. Each road has its price. One can move along any road in any direction. The MST team should carry out the repair works on some set of roads such that one can get from any city to any other one moving only along the repaired roads. Moreover, this set should contain exactly $ k $ capital roads (that is, the roads that start or finish in the capital). The number of the capital is 1. As the budget has already been approved, the MST Company will profit by finding the set with minimum lengths of roads.

输入输出格式

输入格式


The first input line contains three integers $ n,m,k $ ( $ 1<=n<=5000;0<=m<=10^{5};0<=k&lt;5000 $ ), where $ n $ is the number of cities in the country, $ m $ is the number of roads in the country, $ k $ is the number of capital roads in the required set. Then $ m $ lines enumerate the roads in question. Each road is specified by three numbers $ a_{i},b_{i},w_{i} $ ( $ 1<=a_{i},b_{i}<=n $ ; $ 1<=w<=10^{5} $ ), where $ a_{i},b_{i} $ are the numbers of cities linked by a road and $ w_{i} $ is its length. Between each pair of cities no more than one road exists. There are no roads that start and finish in one city. The capital's number is 1.

输出格式


In the first line print the number of roads in the required set. The second line should contain the numbers of roads included in the sought set. If the sought set does not exist, print -1.

输入输出样例

输入样例 #1

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

输出样例 #1

3
1 5 2