Time Limit: 3 sec / Memory Limit: 1024 MB
問題文
株式会社リクルートには N 行 N 列のグリッドで表されるサーバ室があります。
サーバ室の上から i 行目( 0 \leq i \lt N )、左から j 列目( 0 \leq j \lt N )のセルを (i, j) と表します。
各セルには、コンピュータを最大1個まで置くことができます。
また、サーバ室には K 種類のコンピュータが 100 個ずつあります。
既に 100 \times K 個のコンピュータが 100 \times K 個のセルに置かれていて、残りの N^2 - 100 \times K 個のセルには何も置かれていません。
Xさんはコンピュータを何度か移動した後、コンピュータ同士をまっすぐなケーブルで接続します。
移動 と 接続 とは次のような操作を指します。
-
移動:動かしたいコンピュータを1個選び、上下左右の四方向に隣接するセルのどれかへ動かします。一度動かしたコンピュータを複数回動かすこともできます。次の条件をすべて満たす必要があります。
- 移動先として他のコンピュータが存在するセルを選ぶことはできない。
- コンピュータをサーバ室の外へ移動することはできない。
-
接続:つなぎたいコンピュータを2個選び、それら同士をまっすぐなケーブルでつなぎます。次の条件をすべて満たす必要があります。
- 選んだ2個のコンピュータは同じ行か同じ列に存在し、間に他のコンピュータが存在しない。
- ケーブルは他のケーブルと交差しない。(あるコンピュータに複数の方向からケーブルを接続することは可能)
- 既にケーブルで直接つながっているコンピュータ同士を再び指定することはできない。
- あるコンピュータの接続先として、そのコンピュータ自身を指定することはできない。
コンピュータたちを接続することでクラスタが作られます。
あるコンピュータ C_i から 別のコンピュータ C_jにケーブルを1回以上通ってたどり着くことができる場合に、またその場合に限り、 C_i と C_j は「同じクラスタに属する」とみなします。
Xさんは上手にクラスタを作り、サーバ室の処理性能をなるべく上げたいです。
サーバ室の処理性能は、クラスタ内に種類が同じコンピュータの組の数が多ければ多いほど上がります。
一方で、クラスタ内に種類が異なるコンピュータの組の数が多ければ多いほどサーバ室の処理性能は下がってしまいます。
厳密には、サーバ室の処理性能は、次のように計算されます。
- サーバ室に置かれている 100 \times K 個のコンピュータを C_0, C_1, \cdots, C_{100K-1} と表す。
-
0 \leq i \lt j \lt 100 \times K を満たす全ての整数の組 (i, j) について、以下の点を計算したものの和をサーバ室の処理性能とする。
- C_i と C_j が同じクラスタに属していて、種類が同じ場合は 1 点
- C_i と C_j が同じクラスタに属していて、種類が異なる場合は -1 点
- C_i と C_j が同じクラスタに属さない場合は 0 点
Xさんの体力は限られているため、移動 を行う回数と 接続 を行う回数の和は 100 \times K 以下である必要があります。
なるべくサーバ室の処理性能が大きくなるような移動と接続の仕方を見つけてください。
得点
1つのテストケースでは、サーバ室の処理性能が 0 点より大きい場合はそれがそのまま得点となり、そうでない場合は 0 点となります。
各テストケースの得点の合計が提出の得点となります。 暫定テストでは、一つ以上のテストケースで不正な出力や制限時間超過をした場合、提出全体の判定がWAやTLEとなります。 システムテストでは、不正な出力や制限時間超過をした場合、そのテストケースのみ 0 点となります。
テストケース数
-
暫定テスト: 50個
- 暫定テストでは、入力の制約を満たす N および K がランダムに選ばれます。
-
システムテスト: 2000個
- システムテストでは、各 N と K の組(計100組)のデータが20個ずつ存在します。
- コンテスト終了後に seeds.txt (sha256=
0a50dccf4689292f69a36be0ea1a99767de055434b854f2b0bc7f1fd40f9033e
) を公開します。
実行時間について
実行時間には多少のブレが生じます。 また、システムテストでは同時に大量の実行を行うため、暫定テストに比べて数%程度実行時間が伸びる現象が確認されています。 そのため、実行時間制限ギリギリの提出がシステムテストでTLEとなる可能性があります。 プログラム内で時間を計測して処理を打ち切るか、実行時間に余裕を持たせるようお願いします。
入力
入力は以下の形式で標準入力から与えられます。
\(\begin{array}{lll} N ~ K & & \\ c_{ 0,0 } & \ldots & c_{ 0,N-1 } \\ \vdots & \ddots & \vdots \\ c_{ N-1,0 } & \ldots & c_{ N-1,N-1 } \end{array}\)
1行目には2つの整数 N と K を含みます。続く N 行のそれぞれには、長さ N の文字列が1つ与えられます。
-
N と K はサーバ室の大きさとコンピュータの種類数を表す整数で、以下のいずれかを満たします。
- K=2 かつ 15 \leq N \leq 39
- K=3 かつ 18 \leq N \leq 42
- K=4 かつ 21 \leq N \leq 45
- K=5 かつ 24 \leq N \leq 48
-
c_{ i,j } は セル (i, j)の初期状態を表す整数で、 0 \leq c_{i,j} \leq K を満たします。
- c_{ i,j } = 0 の場合、コンピュータが置かれていないことを表します。コンピュータが置かれていないセルは必ず N^2 - 100 \times K 個であることが保証されます。
- 1 \leq c_{ i,j } \leq K の場合、種類が c_{i,j} であるコンピュータが置かれていることを表します。各種コンピュータは必ず 100 個ずつ置かれていることが保証されます。
出力
以下の形式で標準出力へ出力してください。
\( X \\ a_0 ~ b_0 ~ c_0 ~ d_0 \\ \vdots \\ a_{X-1} ~ b_{X-1} ~ c_{X-1} ~ d_{X-1} \\ Y \\ e_0 ~ f_0 ~ g_0 ~ h_0 \\ \vdots \\ e_{Y-1} ~ f_{Y-1} ~ g_{Y-1} ~ h_{Y-1} \)
1行目に、移動を行う回数を表す整数 X を出力してください。
続く X 行には、移動の情報を表す4つの整数を移動を行う順に出力してください。
i 行目の整数 a_i, b_i, c_i, d_i は、 (a_i, b_i) に置かれているコンピュータを (c_i, d_i) へ移動することを表します。
その後、接続を行う回数を表す整数 Y を出力してください。
続く Y 行には、接続の情報を表す4つの整数を出力してください。
i 行目の整数 e_i, f_i, g_i, h_i は、 (e_i, f_i) に置かれているコンピュータ と (g_i, h_i) に置かれているコンピュータを接続することを表します。
また、以下の制約をすべて満たす必要があります。満たさない場合はWAとなります。
- 0 \leq X, ~ 0 \leq Y
- X + Y \leq 100 \times K
- 移動と接続は、問題文中に書かれている条件を満たしていること
解が複数出力された場合、一番 最初 のもののみが採点に用いられます。ビジュアライザでは複数出力された解の比較が可能です。
入力生成方法
各ケースはテストケースジェネレータによって生成されています。
テストケースジェネレータはページ下部のリンクより提供しています。
テストケースジェネレータは以下の手順でケースを生成します。厳密には実装を見てください(必ずしも目を通す必要はありません)。
- K は、seed値を4で割った余り + 2 により生成されます。seed値を調整することで特定の K の値を持つ入力を生成できます。
- N は、入力の条件を満たすものの中から一様ランダムに生成されます。
- c_{i,j} は、入力の条件を満たすものの中から一様ランダムに生成されます。
ツール
- Web版ビジュアライザ・入力ジェネレータ: アニメーション表示が可能です。
- ローカル版ビジュアライザ・入力ジェネレータ: 使用するにはRust言語のコンパイル環境をご用意下さい。
- サンプルコード(C++, Python): そのまま提出もできるサンプルの解答です。次の処理を実装しています。
- ランダムな移動を何度か行う
- それぞれのコンピュータから、右と下に向かって、同じ種類のコンピュータに接続できるならする
- スコアを計算し、標準エラー出力に出力する
コンテスト終了までビジュアライズ結果の共有は禁止されています。ご注意下さい。
入力例 1 Copy
5 2 10000 00000 00200 00000 00111この入力は説明用のものなので、入力の制約を満たさないことに注意してください。
出力例 1 Copy
2 0 0 0 1 0 1 0 2 4 0 2 2 2 2 2 4 2 4 2 4 3 4 3 4 4
- (0,0) にあるコンピュータを2回連続で移動し、 (0,2) へ動かします。
- すべてのコンピュータを接続します。
-
この時のサーバ室の処理性能は2となります。
- すべてのコンピュータからなるクラスタが1つあり、種類1のコンピュータが4個、種類2のコンピュータが1個で構成されています。
- クラスタ内に種類1同士のコンピュータの組は {4 \choose 2} = 6 つあり、種類1と種類2のコンピュータの組は 4 \times 1 = 4つあるので、 6 - 4 = 2 が サーバ室の処理性能 となります。
入力例 2 Copy
33 3 200000020020030300300012000000200 000000000333000000002200002030201 000100010000003200020000031001010 000023200000000000202300010000030 000010000023000300310300003000010 100010030001000032100000000103000 000000030100030300000000002000000 100000000120200000000000001001000 120030000200000000001001032000302 000000020003033020000013020002301 030000301300000000020200002003000 002000000020000000030103002000100 331210020020020000200200200103000 000202320000003000000000001000000 000010010030000303120001200000001 103000022010000313000000000000003 000012000010000001000000030000030 002000200003010100000002332000000 000003023000230020000003030000130 010000020001202302210002102030000 000003000000100002002000002002000 010003000200200000010030103000212 001000300000300000130020000003120 000000320300200100300000030002200 000000100003000000020100000300000 010000130110030200200100000110000 000231100000113000102000201003010 000000100030100230000000021000030 300103010000010100100300001022000 201021000001001000020000002000333 000002030300000000030000103100300 020000110320030200012100001030300 000100000010000000020001220030021このケースは、テストケースジェネレータを seed=
1
で実行すると生成されます。出力例は省略します。
Problem Statement
Recruit Co. has a server room represented by a grid of N rows and N columns.
Let (i, j) denote the cell in row i (0 \leq i \lt N) from the top and column j (0 \leq j \lt N) from the left of the server room.
Each cell can contain up to one computer.
There are K types of computers and 100 computers of each type in the server room.
In the beginning, 100 \times K computers are already placed in 100 \times K cells, and the remaining N^2 - 100 \times K cells are empty.
X-san can move computers around first, and then connect them with straight cables.
Move and Connect is defined as follows:
-
Move : Select one of the computers and move it to one of the adjacent cells, up, down, left, or right. You can move a computer multiple times. All of the following requirements should be met for each movement:
- You cannot move a computer to a cell where another computer is already located.
- You cannot move a computer outside the grid.
-
Connect : Select two computers and connect them to each other with a straight cable. All of the following requirements should be met for each connection:
- The two computers you choose must be on the same row or in the same column, with no other computers in between.
- The cables do not intersect with any other cables. (Connecting multiple cables in one computer is allowed.)
- You cannot connect the same pair of computers twice.
- The two computers you choose must be different (one cannot connect a computer to itself with a single cable).
Clusters are created by connecting computers.
Computers C_i and C_j are considered to be "in the same cluster" if and only if computer C_j can be reached from computer C_i by a path over computers connected with cables.
X-san wants to create good clusters and increase the processing performance of the server room as much as possible.
The more pairs of computers of the same type in a cluster, the better the processing performance of the server room.
On the other hand, the more pairs of computers of different types there are in the cluster, the lower the processing performance of the server room.
The processing performance of a server room is calculated as follows:
- Denote the 100 \times K computers in the server room as C_0, C_1, \cdots, C_{100K-1}
-
The processing performance of the server room is the sum of the following points summed over every integer pair (i, j) satisfying 0 \leq i \lt j \lt 100 \times K:
- 1 point if C_i and C_j belong to the same cluster and have the same type
- -1 point if C_i and C_j belong to the same cluster and are of different types
- 0 points if C_i and C_j do not belong to the same cluster
Considering the physical burden of X-san, the number of moves and the number of connections must be less than or equal to 100 \times K in total.
Your challenge is to find a way to maximize the processing performance of the server room under all the restrictions we’ve placed above.
Scoring
In each test case, if the processing performance of the server room is greater than 0 points, it will be the score of the case; otherwise, the test case will be scored 0 points.
The score of a submission is the total scores for each test case. In the provisional test, if your submission produces illegal output or exceeds the time limit for some test cases, the submission itself will be judged as WA or TLE , and the score of the submission will be zero. In the system test, if your submission produces illegal output or exceeds the time limit for some test cases, only the score for those test cases will be zero.
Number of test cases
-
Provisional test: 50
- In provisional testing, N and K that satisfy the input constraints are randomly selected.
-
System test: 2000
- For the system test, there will be 20 data inputs for each N and K pair (100 pairs in total).
- We will publish seeds.txt (sha256=
0a50dccf4689292f69a36be0ea1a99767de055434b854f2b0bc7f1fd40f9033e
) after the contest is over.
About execution time
Execution time may vary slightly from run to run. In addition, since system tests simultaneously perform a large number of executions, it has been observed that execution time increases by several percents compared to provisional tests. For these reasons, submissions that are very close to the time limit may result in TLE in the system test. Please measure the execution time in your program to terminate the process, or make sure to have enough time margin for the execution.
Input
Input is given from standard input (stdin) in the following format:
\(\begin{array}{lll} N ~ K & & \\ c_{ 0,0 } & \ldots & c_{ 0,N-1 } \\ \vdots & \ddots & \vdots \\ c_{ N-1,0 } & \ldots & c_{ N-1,N-1 } \end{array}\)
The first line contains two integers N and K. Each of the following N lines is given one string of length N.
-
N and K are integers representing the size of the server room and the number of computer types, satisfying one of the following
- K=2 and 15 \leq N \leq 39
- K=3 and 18 \leq N \leq 42
- K=4 and 21 \leq N \leq 45
- K=5 and 24 \leq N \leq 48
-
c_{ i,j } is an integer representing the initial state of the i-th cell from the top and j-th cell from the left in the server room. 0 \leq c_{i,j} \leq K .
- c_{i,j} = 0 means that no computer is placed in the cell (i, j). There are always N^2 - 100 \times K cells without a computer.
- if 1 \leq c_{ i,j } \leq K, it means the computer of type c_{i,j} is placed in the cell (i,j). It is guaranteed that 100 computers of each type are placed in the grid.
Output
Please output to standard output (stdout) in the following format:
\( X \\ a_0 ~ b_0 ~ c_0 ~ d_0 \\ \vdots \\ a_{X-1} ~ b_{X-1} ~ c_{X-1} ~ d_{X-1} \\ Y \\ e_0 ~ f_0 ~ g_0 ~ h_0 \\ \vdots \\ e_{Y-1} ~ f_{Y-1} ~ g_{Y-1} ~ h_{Y-1} \)
On the first line, output an integer X representing the number of moves to be made.
On the following X lines, output four integers representing the information on the moves in the order in which they are to be made.
The integers a_i, b_i, c_i, d_i on line i represent moving the computer located at (a_i, b_i) to (c_i, d_i)
Then output an integer Y representing the number of connections to be made.
On the following Y lines, output four integers representing the information of the connection.
The integers e_i, f_i, g_i, h_i on line i represent the connection between the computer located at (e_i, f_i) and the computer located at (g_i, h_i).
In addition, all of the following constraints must be satisfied, or the submission will be judged as a WA.
- 0 \leq X, ~ 0 \leq Y
- X + Y \leq 100 \times K
- The moves and the connections must satisfy the conditions written in the problem statement
If you output more than one solution, only the first one is used for scoring. You can compare solutions by using the web visualizer.
Input Generation
Each case is generated by a test case generator.
The test case generator is provided at the link at the bottom of the page.
The test case generator generates cases in the following steps. For details, see the exact implementation (you are not required to read it through, however).
- K is generated by the \mathit{seed} \mod 4 + 2. By adjusting the seed value, an input with a specific K value can be generated.
- N is generated uniformly at random from among those satisfying the input conditions.
- c_{i,j} is generated uniformly at random from among those satisfying the input conditions.
Tools
- Input generator and visualizer (Web version): This can display animations.
- Input generator and visualizer (Local version): You need a compilation environment of Rust language.
- Sample solution (C++, Python): They implement the following:
- Make several random moves
- From each computer, connect to right and/or bottom if it can reach a computer of the same type
- Calculate the score and output it to stderr
Sharing visualization results is not allowed until the end of the contest.
Sample Input 1 Copy
5 2 10000 00000 00200 00000 00111Note that this input is for explanatory purposes only and does not meet the constraints of the input.
Sample Output 1 Copy
2 0 0 0 1 0 1 0 2 4 0 2 2 2 2 2 4 2 4 2 4 3 4 3 4 4
- Move the computer at (0, 0) to (0, 2) by moving twice.
- Connect all computers.
-
The processing performance of the server room at this time is 2.
- There is one cluster consisting of all computers, 4 computers of type 1 and 1 computer of type 2.
- The pairs of type 1 computers in the cluster are {4 \choose 2} = 6, and there are 4 \times 1 = 4 pairs of computers between type 1 and type 2 in the cluster, so the processing performance of the server room is 6 - 4 = 2 .
Sample Input 2 Copy
33 3 200000020020030300300012000000200 000000000333000000002200002030201 000100010000003200020000031001010 000023200000000000202300010000030 000010000023000300310300003000010 100010030001000032100000000103000 000000030100030300000000002000000 100000000120200000000000001001000 120030000200000000001001032000302 000000020003033020000013020002301 030000301300000000020200002003000 002000000020000000030103002000100 331210020020020000200200200103000 000202320000003000000000001000000 000010010030000303120001200000001 103000022010000313000000000000003 000012000010000001000000030000030 002000200003010100000002332000000 000003023000230020000003030000130 010000020001202302210002102030000 000003000000100002002000002002000 010003000200200000010030103000212 001000300000300000130020000003120 000000320300200100300000030002200 000000100003000000020100000300000 010000130110030200200100000110000 000231100000113000102000201003010 000000100030100230000000021000030 300103010000010100100300001022000 201021000001001000020000002000333 000002030300000000030000103100300 020000110320030200012100001030300 000100000010000000020001220030021This case is generated by running the test case generator with seed=
1
. Output examples are omitted.