Codeforces celebrates 10 years! We are pleased to announce the crowdfunding-campaign. Congratulate us by the link https://codeforces.com/10years.
×

Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only ICPC mode for virtual contests.
If you've seen these problems, a virtual contest is not for you - solve these problems in the archive.
If you just want to solve some problem from a contest, a virtual contest is not for you - solve this problem in the archive.
Never use someone else's code, read the tutorials or communicate with other person during a virtual contest.

No tag edit access

D. Berland Federalization

time limit per test

1 secondmemory limit per test

256 megabytesinput

standard inputoutput

standard outputRecently, Berland faces federalization requests more and more often. The proponents propose to divide the country into separate states. Moreover, they demand that there is a state which includes exactly *k* towns.

Currently, Berland has *n* towns, some pairs of them are connected by bilateral roads. Berland has only *n* - 1 roads. You can reach any city from the capital, that is, the road network forms a tree.

The Ministry of Roads fears that after the reform those roads that will connect the towns of different states will bring a lot of trouble.

Your task is to come up with a plan to divide the country into states such that:

- each state is connected, i.e. for each state it is possible to get from any town to any other using its roads (that is, the roads that connect the state towns),
- there is a state that consisted of exactly
*k*cities, - the number of roads that connect different states is minimum.

Input

The first line contains integers *n*, *k* (1 ≤ *k* ≤ *n* ≤ 400). Then follow *n* - 1 lines, each of them describes a road in Berland. The roads are given as pairs of integers *x*_{i}, *y*_{i} (1 ≤ *x*_{i}, *y*_{i} ≤ *n*; *x*_{i} ≠ *y*_{i}) — the numbers of towns connected by the road. Assume that the towns are numbered from 1 to *n*.

Output

The the first line print the required minimum number of "problem" roads *t*. Then print a sequence of *t* integers — their indices in the found division. The roads are numbered starting from 1 in the order they follow in the input. If there are multiple possible solutions, print any of them.

If the solution shows that there are no "problem" roads at all, print a single integer 0 and either leave the second line empty or do not print it at all.

Examples

Input

5 2

1 2

2 3

3 4

4 5

Output

1

2

Input

5 3

1 2

1 3

1 4

1 5

Output

2

3 4

Input

1 1

Output

0

Codeforces (c) Copyright 2010-2020 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Feb/18/2020 05:33:45 (h1).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|