Package for this problem was not updated by the problem writer or Codeforces administration after we’ve upgraded the judging servers. To adjust the time limit constraint, solution execution time will be multiplied by 2. For example, if your solution works for 400 ms on judging servers, then value 800 ms will be displayed and used to determine the verdict.

Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only ACM-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

B. Discounts

time limit per test

3 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputOne day Polycarpus stopped by a supermarket on his way home. It turns out that the supermarket is having a special offer for stools. The offer is as follows: if a customer's shopping cart contains at least one stool, the customer gets a 50% discount on the cheapest item in the cart (that is, it becomes two times cheaper). If there are several items with the same minimum price, the discount is available for only one of them!

Polycarpus has *k* carts, and he wants to buy up all stools and pencils from the supermarket. Help him distribute the stools and the pencils among the shopping carts, so that the items' total price (including the discounts) is the least possible.

Polycarpus must use all *k* carts to purchase the items, no shopping cart can remain empty. Each shopping cart can contain an arbitrary number of stools and/or pencils.

Input

The first input line contains two integers *n* and *k* (1 ≤ *k* ≤ *n* ≤ 10^{3}) — the number of items in the supermarket and the number of carts, correspondingly. Next *n* lines describe the items as "*c*_{i} *t*_{i}" (without the quotes), where *c*_{i} (1 ≤ *c*_{i} ≤ 10^{9}) is an integer denoting the price of the *i*-th item, *t*_{i} (1 ≤ *t*_{i} ≤ 2) is an integer representing the type of item *i* (1 for a stool and 2 for a pencil). The numbers in the lines are separated by single spaces.

Output

In the first line print a single real number with exactly one decimal place — the minimum total price of the items, including the discounts.

In the following *k* lines print the descriptions of the items in the carts. In the *i*-th line print the description of the *i*-th cart as "*t* *b*_{1} *b*_{2} ... *b*_{t}" (without the quotes), where *t* is the number of items in the *i*-th cart, and the sequence *b*_{1}, *b*_{2}, ..., *b*_{t} (1 ≤ *b*_{j} ≤ *n*) gives the indices of items to put in this cart in the optimal distribution. All indices of items in all carts should be pairwise different, each item must belong to exactly one cart. You can print the items in carts and the carts themselves in any order. The items are numbered from 1 to *n* in the order in which they are specified in the input.

If there are multiple optimal distributions, you are allowed to print any of them.

Examples

Input

3 2

2 1

3 2

3 1

Output

5.5

2 1 2

1 3

Input

4 3

4 1

1 2

2 2

3 2

Output

8.0

1 1

2 4 2

1 3

Note

In the first sample case the first cart should contain the 1st and 2nd items, and the second cart should contain the 3rd item. This way each cart has a stool and each cart has a 50% discount for the cheapest item. The total price of all items will be: 2·0.5 + (3 + 3·0.5) = 1 + 4.5 = 5.5.

Codeforces (c) Copyright 2010-2019 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Jul/17/2019 08:43:51 (e1).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|