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

C. New Year Presents

time limit per test

2 secondsmemory limit per test

512 megabytesinput

standard inputoutput

standard outputSanta has prepared boxes with presents for $$$n$$$ kids, one box for each kid. There are $$$m$$$ kinds of presents: balloons, sweets, chocolate bars, toy cars... A child would be disappointed to receive two presents of the same kind, so all kinds of presents in one box are distinct.

Having packed all the presents, Santa realized that different boxes can contain different number of presents. It would be unfair to the children, so he decided to move some presents between boxes, and make their sizes similar. After all movements, the difference between the maximal and the minimal number of presents in a box must be as small as possible. All presents in each box should still be distinct. Santa wants to finish the job as fast as possible, so he wants to minimize the number of movements required to complete the task.

Given the sets of presents in each box, find the shortest sequence of movements of presents between boxes that minimizes the difference of sizes of the smallest and the largest box, and keeps all presents in each box distinct.

Input

The first line of input contains two integers $$$n$$$, $$$m$$$ ($$$1 \leq n, m \leq 100\ 000$$$), the number of boxes and the number of kinds of the presents. Denote presents with integers from $$$1$$$ to $$$m$$$.

Each of the following $$$n$$$ lines contains the description of one box. It begins with an integer $$$s_i$$$ ($$$s_i \geq 0$$$), the number of presents in the box, $$$s_i$$$ distinct integers between $$$1$$$ and $$$m$$$ follow, denoting the kinds of presents in that box.

The total number of presents in all boxes does not exceed $$$500\,000$$$.

Output

Print one integer $$$k$$$ at the first line of output, the number of movements in the shortest sequence that makes the sizes of the boxes differ by at most one. Then print $$$k$$$ lines that describe movements in the same order in which they should be performed. Each movement is described by three integers $$$from_i$$$, $$$to_i$$$, $$$kind_i$$$. It means that the present of kind $$$kind_i$$$ is moved from the box with number $$$from_i$$$ to the box with number $$$to_i$$$. Boxes are numbered from one in the order they are given in the input.

At the moment when the movement is performed the present with kind $$$kind_i$$$ must be present in the box with number $$$from_i$$$. After performing all moves each box must not contain two presents of the same kind.

If there are several optimal solutions, output any of them.

Example

Input

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

Output

2 1 3 5 1 2 3

Codeforces (c) Copyright 2010-2019 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Jun/26/2019 08:10:04 (e3).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|