Preparando MOJI

Copy of a Copy of a Copy

2000ms 262144K

Description:

It all started with a black-and-white picture, that can be represented as an $$$n \times m$$$ matrix such that all its elements are either $$$0$$$ or $$$1$$$. The rows are numbered from $$$1$$$ to $$$n$$$, the columns are numbered from $$$1$$$ to $$$m$$$.

Several operations were performed on the picture (possibly, zero), each of one of the two kinds:

  • choose a cell such that it's not on the border (neither row $$$1$$$ or $$$n$$$, nor column $$$1$$$ or $$$m$$$) and it's surrounded by four cells of the opposite color (four zeros if it's a one and vice versa) and paint it the opposite color itself;
  • make a copy of the current picture.

Note that the order of operations could be arbitrary, they were not necessarily alternating.

You are presented with the outcome: all $$$k$$$ copies that were made. Additionally, you are given the initial picture. However, all $$$k+1$$$ pictures are shuffled.

Restore the sequence of the operations. If there are multiple answers, print any of them. The tests are constructed from the real sequence of operations, i. e. at least one answer always exists.

Input:

The first line contains three integers $$$n, m$$$ and $$$k$$$ ($$$3 \le n, m \le 30$$$; $$$0 \le k \le 100$$$) — the number of rows and columns of the pictures and the number of copies made, respectively.

Then $$$k+1$$$ pictures follow — $$$k$$$ copies and the initial picture. Their order is arbitrary.

Each picture consists of $$$n$$$ lines, each consisting of $$$m$$$ characters, each character is either $$$0$$$ or $$$1$$$. There is an empty line before each picture.

Output:

In the first line, print a single integer — the index of the initial picture. The pictures are numbered from $$$1$$$ to $$$k+1$$$ in the order they appear in the input.

In the second line, print a single integer $$$q$$$ — the number of operations.

Each of the next $$$q$$$ lines should contain an operation. The operations should be listed in order they were applied. Each operation is one of two types:

  • $$$1$$$ $$$x$$$ $$$y$$$ — recolor a cell $$$(x, y)$$$ (the $$$y$$$-th cell in the $$$x$$$-th row, it should not be on the border and it should be surrounded by four cells of opposite color to itself);
  • $$$2$$$ $$$i$$$ — make a copy of the current picture and assign it index $$$i$$$ (picture with index the $$$i$$$ should be equal to the current picture).

Each index from $$$1$$$ to $$$k+1$$$ should appear in the output exactly once — one of them is the index of the initial picture, the remaining $$$k$$$ are arguments of the operations of the second kind.

If there are multiple answers, print any of them. The tests are constructed from the real sequence of operations, i. e. at least one answer always exists.

Sample Input:

3 3 1

010
111
010

010
101
010

Sample Output:

2
2
1 2 2
2 1

Sample Input:

4 5 3

00000
01000
11100
01000

00000
01000
10100
01000

00000
01010
10100
01000

00000
01000
10100
01000

Sample Output:

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

Sample Input:

5 3 0

110
010
001
011
001

Sample Output:

1
0

Informação

Codeforces

Provedor Codeforces

Código CF1772F

Tags

constructive algorithmsdfs and similargraphsimplementationsortings

Submetido 0

BOUA! 0

Taxa de BOUA's 0%

Datas 09/05/2023 10:34:53

Relacionados

Nada ainda