Description:
You are given a bipartite graph G = (U, V, E), U is the set of vertices of the first part, V is the set of vertices of the second part and E is the set of edges. There might be multiple edges.
Let's call some subset of its edges $$\widetilde{E}$$ k-covering iff the graph $${ \bar { G } } = ( U, V, { \bar { E } } )$$ has each of its vertices incident to at least k edges. Minimal k-covering is such a k-covering that the size of the subset $$\widetilde{E}$$ is minimal possible.
Your task is to find minimal k-covering for each $$k \in [0..minDegree]$$, where minDegree is the minimal degree of any vertex in graph G.
Input Format:
The first line contains three integers n1, n2 and m (1 ≤ n1, n2 ≤ 2000, 0 ≤ m ≤ 2000) — the number of vertices in the first part, the number of vertices in the second part and the number of edges, respectively.
The i-th of the next m lines contain two integers ui and vi (1 ≤ ui ≤ n1, 1 ≤ vi ≤ n2) — the description of the i-th edge, ui is the index of the vertex in the first part and vi is the index of the vertex in the second part.
Output Format:
For each $$k \in [0..minDegree]$$ print the subset of edges (minimal k-covering) in separate line.
The first integer cntk of the k-th line is the number of edges in minimal k-covering of the graph. Then cntk integers follow — original indices of the edges which belong to the minimal k-covering, these indices should be pairwise distinct. Edges are numbered 1 through m in order they are given in the input.
Note:
None