A - future_fif_digital_days_open_a

Time Limit: 2 sec / Memory Limit: 1024 MB

A,B,Cの3つの問題はテストケース数と入力の生成方法のみが異なります。

問題文

N\times N マスの盤面と B 種類のポリオミノがある。 一番左上のマスの座標を (0, 0) とし、そこから下へ i マス、右へ j マス移動した先のマスの座標を (i, j) と定める。 初期状態で全てのマスは通行不能であり、ポリオミノを盤面に配置するとその上が通行可能になる。 盤面上の K 個のマスに印が付いており、ポリオミノを配置することで全ての印が付けられたマスが連結になるようにしたい。

例えば、上の図では左上の印と右上の印は連結になっているが、下の印とは連結になっていない。

同一種類のポリオミノを任意個配置することが出来るが、回転させたり、盤面からはみ出すように配置することは出来ない。 また、1つのマスの上に2つ以上のポリオミノを重ねて配置することも出来ない。 各ポリオミノの種類 b ごとにコスト C_b が定まっており、ポリオミノ bm_b 個配置したとき、合計コストは \sum_{b=1}^B C_b m_b となる。 出来るだけ小さい合計コストで全ての印が付けられたマスを連結にしてほしい。

得点

合計コストを S とすると、\mathrm{round}(10^8 / S) の得点が得られる。 不正な出力(印のついたマスが連結になっていない、ポリオミノが盤面からはみ出している、もしくは重なっている)がされた場合、と判定される。 1つ以上のテストケースで以外の判定がされた場合、提出の得点は0点となる。 コンテスト時間中に得た最高得点で最終順位が決定され、コンテスト終了後のシステムテストは行われない。 同じ得点を複数の参加者が得た場合、その得点を獲得した提出の早い方が上位となる。


入力

入力は以下の形式で標準入力から与えられる。

N K B
i_1 j_1
\vdots
i_K j_K
n_1 m_1 C_1
s^1_{1,1} \ldots s^1_{1,m_1}
\vdots
s^1_{n_1,1} \ldots s^1_{n_1,m_1}
\vdots
n_B m_B C_B
s^B_{1,1} \ldots s^B_{1,m_B}
\vdots
s^B_{n_B,1} \ldots s^B_{n_B,m_B}

一行目には盤面の縦・横の大きさを表す整数 N、印が付けられたマスの総数 K、ポリオミノの種類数 B が与えられる。全てのテストケースで N=50 で固定である。

続く K 行には印の付いたマスの情報が与えられ、その p 行目は p 番目の印の座標が (i_p, j_p) であることを表し、0\leq i_p\leq N-1, 0\leq j_p\leq N-1 を満たす。 印の座標は全て異なる。

最後に B 種類のポリオミノに関する情報が一つずつ与えられる。

  • n_bm_bb 番目のポリオミノを囲う最小の長方形(バウンディングボックス)の縦・横の大きさを表す。n_1=m_1=1 であることが保証されている。
  • C_bb 番目のポリオミノを1つ配置するのに必要なコストを表す正の整数である。
  • s^b_{i,j}b 番目のポリオミノのバウンディングボックスの上から i マス目、左から j マス目の情報を表し、# の場合はポリオミノに属し、. の場合はポリオミノに属さないことを表している。
  • 各ポリオミノは連結であることが保証されている。

出力

以下の形式で、一行目に使用するポリオミノの総数 m を、続く m 行には使用するポリオミノの種類を表す整数 b_i (1\leq b_i\leq B) とバウンディングボックスの左上の座標 (x_i, y_i) (0\leq x_i\leq N-n_{b_i}, 0\leq y_i\leq N-m_{b_i})を一行ずつ出力せよ。

m
b_1 x_1 y_1
\vdots
b_m x_m y_m

テストケース数

1 個

入力生成方法

A問題のテストケース数は1つであり、入力例 1 と同一である。 手動等により事前に計算した出力のみを提出しても構わない。


入力例 1

50 70 11
0 0
35 0
49 14
8 49
0 2
1 19
41 31
30 18
3 8
44 10
32 42
27 27
0 27
17 3
28 18
17 48
4 13
1 21
17 17
10 25
14 16
35 36
19 7
25 12
6 46
25 24
18 32
31 47
15 12
41 15
24 16
49 22
49 17
29 42
30 32
22 8
36 39
9 12
7 7
20 46
16 15
17 34
16 21
17 28
46 4
26 21
45 17
10 32
26 35
45 31
40 45
28 45
0 20
17 22
45 9
33 34
39 20
46 20
30 5
10 48
9 37
26 37
29 30
29 46
41 19
0 4
4 47
6 37
36 2
2 25
1 1 1
#
7 4 2
####
#...
#...
###.
#...
#...
#...
4 5 2
#...#
#...#
#...#
#####
8 3 2
###
.#.
.#.
.#.
.#.
.#.
.#.
.#.
4 5 2
####.
#..##
####.
#..##
5 4 2
####
#...
###.
#...
####
4 4 2
####
#..#
#..#
####
5 8 3
#......#
#......#
########
#......#
#......#
8 7 3
..###..
.##.##.
##...##
#.....#
#######
#.....#
#.....#
#.....#
8 8 3
..######
.##.....
##......
#.......
#.......
##......
.##.....
..######
9 6 3
#....#
#...##
#..##.
#.##..
###...
#.##..
#..##.
#...##
#....#

出力例 1

326
1 0 0
1 0 1
1 0 2
1 0 3
1 0 4
1 1 19
1 1 20
1 1 21
1 0 20
1 30 18
1 29 18
1 28 18
1 44 10
1 44 9
1 45 9
1 16 21
1 16 22
1 17 22
1 26 35
1 26 36
1 26 37
1 28 45
1 28 46
1 29 46
1 35 0
1 35 1
1 35 2
1 36 2
1 49 14
1 49 15
1 49 16
1 49 17
1 8 49
1 8 48
1 9 48
1 10 48
1 32 42
1 31 42
1 30 42
1 29 42
1 17 17
1 16 17
1 16 16
1 16 15
1 14 16
1 15 16
1 6 46
1 5 46
1 4 46
1 4 47
1 18 32
1 17 32
1 17 33
1 17 34
1 31 47
1 30 47
1 29 47
1 30 32
1 29 32
1 29 31
1 29 30
1 39 20
1 39 19
1 40 19
1 41 19
1 9 37
1 8 37
1 7 37
1 6 37
1 41 31
1 42 31
1 43 31
1 44 31
1 45 31
1 0 27
1 0 26
1 0 25
1 1 25
1 2 25
1 35 36
1 35 37
1 35 38
1 35 39
1 36 39
1 34 36
1 33 36
1 33 35
1 33 34
1 19 7
1 19 8
1 20 8
1 21 8
1 22 8
1 25 24
1 25 23
1 25 22
1 25 21
1 26 21
1 15 12
1 15 13
1 15 14
1 15 15
1 41 15
1 41 16
1 41 17
1 41 18
1 48 17
1 47 17
1 46 17
1 45 17
1 28 42
1 28 43
1 28 44
1 46 18
1 46 19
1 46 20
1 7 48
1 6 48
1 6 47
1 3 8
1 3 7
1 4 7
1 5 7
1 6 7
1 7 7
1 27 27
1 26 27
1 25 27
1 25 26
1 25 25
1 27 28
1 27 29
1 27 30
1 28 30
1 27 18
1 26 18
1 26 19
1 26 20
1 17 48
1 17 47
1 17 46
1 18 46
1 19 46
1 20 46
1 1 22
1 1 23
1 1 24
1 16 18
1 16 19
1 16 20
1 25 12
1 24 12
1 24 13
1 24 14
1 24 15
1 24 16
1 17 31
1 17 30
1 17 29
1 17 28
1 49 22
1 48 22
1 47 22
1 46 22
1 46 21
1 30 33
1 30 34
1 31 34
1 32 34
1 3 9
1 3 10
1 3 11
1 3 12
1 3 13
1 4 13
1 17 3
1 17 4
1 17 5
1 17 6
1 17 7
1 18 7
1 25 18
1 24 18
1 24 17
1 4 12
1 5 12
1 6 12
1 7 12
1 8 12
1 9 12
1 14 12
1 13 12
1 12 12
1 11 12
1 10 12
1 42 17
1 43 17
1 44 17
1 17 27
1 17 26
1 17 25
1 17 24
1 17 23
1 46 4
1 45 4
1 45 5
1 45 6
1 45 7
1 45 8
1 10 32
1 9 32
1 9 33
1 9 34
1 9 35
1 9 36
1 2 7
1 1 7
1 0 7
1 0 6
1 0 5
1 32 41
1 32 40
1 32 39
1 33 39
1 34 39
1 16 48
1 15 48
1 14 48
1 13 48
1 12 48
1 11 48
1 10 25
1 10 26
1 10 27
1 10 28
1 10 29
1 10 30
1 10 31
1 23 12
1 22 12
1 22 11
1 22 10
1 22 9
1 29 34
1 28 34
1 27 34
1 26 34
1 44 11
1 44 12
1 44 13
1 44 14
1 44 15
1 44 16
1 15 11
1 15 10
1 15 9
1 15 8
1 15 7
1 16 7
1 9 25
1 8 25
1 7 25
1 6 25
1 5 25
1 4 25
1 3 25
1 16 25
1 15 25
1 14 25
1 13 25
1 12 25
1 11 25
1 21 46
1 22 46
1 23 46
1 24 46
1 25 46
1 26 46
1 27 46
1 30 5
1 30 4
1 30 3
1 30 2
1 31 2
1 32 2
1 33 2
1 34 2
1 36 40
1 36 41
1 36 42
1 36 43
1 36 44
1 36 45
1 37 45
1 38 45
1 39 45
1 40 45
1 40 31
1 39 31
1 38 31
1 37 31
1 36 31
1 35 31
1 34 31
1 33 31
1 33 32
1 33 33
1 30 19
1 31 19
1 32 19
1 33 19
1 34 19
1 35 19
1 36 19
1 37 19
1 38 19
1 22 7
1 22 6
1 22 5
1 23 5
1 24 5
1 25 5
1 26 5
1 27 5
1 28 5
1 29 5
B - future_fif_digital_days_open_b

Time Limit: 2 sec / Memory Limit: 1024 MB

A,B,Cの3つの問題はテストケース数と入力の生成方法のみが異なります。共通部分はA問題を参照下さい。

テストケース数

50 個

入力生成方法

K=10B=20 で固定する。 印の座標は、既に配置した印からのマンハッタン距離の最小値が10以上となる座標の中から一様ランダムに選択することで生成する。 ただし、1つ目の印は上端 (i_1=0)、2つ目の印は左端 (j_2=0)、3つ目の印は下端 (i_3=N-1)、4つ目の印は右端 (j_4=N-1) の中に絞り込んで一様ランダムに選択する。

各ポリオミノは以下のように生成する。 ポリオミノを構成する各正方形をブロックと呼ぶことにする。 1つ目のポリオミオは1ブロックからなり、コストはC_1=50とする。 b (2\leq b\leq B) 番目のポリオミノは 2+b ブロックからなり、コストは C_b=\mathrm{round}(50\sqrt{2+b}) で、1ブロックのポリオミノから開始して以下の拡張操作を 1+b 回繰り返すことで生成する。

  1. 拡張する方向を上下左右の4方向の中から一様ランダムに選択する。
  2. その方向に向かって一番端にあるブロックの中から一様ランダムに選択し、その方向に隣接するマスをポリオミノに含めることで1ブロック拡張する。

入力例 1

50 10 20
0 25
1 0
49 21
49 49
0 43
41 9
26 6
12 32
38 33
13 4
1 1 50
#
2 3 100
###
#..
2 4 112
#...
####
5 2 122
.#
.#
##
#.
#.
3 5 132
..###
###..
.#...
2 7 141
###....
..#####
7 3 150
..#
..#
..#
..#
..#
..#
###
5 6 158
...#..
..####
..#...
###...
.#....
7 5 166
...#.
...#.
...#.
####.
...##
...#.
...#.
5 8 173
...#....
...#....
########
.....#..
.....#..
9 5 180
..#..
..#..
..#..
..#..
#####
..#..
..#..
..#..
..#..
8 7 187
..#....
..#....
..#....
..#....
#######
.#.....
.#.....
.#.....
8 8 194
.......#
.....###
######..
...#....
...#....
...#....
...#....
...#....
5 12 200
.......#....
.......#####
########....
.....#......
.....#......
12 6 206
...#..
...#..
...#..
...#..
...#..
...###
####..
...#..
...#..
...#..
...#..
...#..
10 9 212
.......#.
.......#.
.......#.
#########
.......#.
.......#.
.......#.
.......#.
.......#.
.......#.
14 6 218
...#..
...#..
...#..
...#..
...#..
######
...#..
...#..
...#..
...#..
...#..
...#..
...#..
...#..
9 12 224
.....#......
.....#......
.....#......
.....#......
.....#......
.....#......
######......
.....##.....
......######
9 13 229
........#....
........#....
........#....
........#....
#############
.......#.....
.......#.....
.......#.....
.......#.....
10 13 235
.....#.......
.....#.......
.....#.......
#######......
......#......
......#######
......#......
......#......
......#......
......#......

出力例 1

164
1 26 6
1 25 6
1 24 6
1 23 6
1 22 6
1 21 6
1 20 6
1 19 6
1 18 6
1 17 6
1 16 6
1 15 6
1 14 6
1 13 6
1 13 5
1 13 4
1 1 0
1 1 1
1 1 2
1 1 3
1 1 4
1 2 4
1 3 4
1 4 4
1 5 4
1 6 4
1 7 4
1 8 4
1 9 4
1 10 4
1 11 4
1 12 4
1 0 25
1 0 26
1 0 27
1 0 28
1 0 29
1 0 30
1 0 31
1 0 32
1 0 33
1 0 34
1 0 35
1 0 36
1 0 37
1 0 38
1 0 39
1 0 40
1 0 41
1 0 42
1 0 43
1 41 9
1 40 9
1 39 9
1 38 9
1 37 9
1 36 9
1 35 9
1 34 9
1 33 9
1 32 9
1 31 9
1 30 9
1 29 9
1 28 9
1 27 9
1 26 9
1 26 8
1 26 7
1 1 32
1 2 32
1 3 32
1 4 32
1 5 32
1 6 32
1 7 32
1 8 32
1 9 32
1 10 32
1 11 32
1 12 32
1 49 21
1 48 21
1 47 21
1 46 21
1 45 21
1 44 21
1 43 21
1 42 21
1 41 21
1 41 20
1 41 19
1 41 18
1 41 17
1 41 16
1 41 15
1 41 14
1 41 13
1 41 12
1 41 11
1 41 10
1 40 21
1 39 21
1 38 21
1 38 22
1 38 23
1 38 24
1 38 25
1 38 26
1 38 27
1 38 28
1 38 29
1 38 30
1 38 31
1 38 32
1 38 33
1 0 24
1 0 23
1 0 22
1 0 21
1 0 20
1 0 19
1 0 18
1 0 17
1 0 16
1 0 15
1 0 14
1 0 13
1 0 12
1 0 11
1 0 10
1 0 9
1 0 8
1 0 7
1 0 6
1 0 5
1 0 4
1 49 49
1 48 49
1 47 49
1 46 49
1 45 49
1 44 49
1 43 49
1 42 49
1 41 49
1 40 49
1 39 49
1 38 49
1 38 48
1 38 47
1 38 46
1 38 45
1 38 44
1 38 43
1 38 42
1 38 41
1 38 40
1 38 39
1 38 38
1 38 37
1 38 36
1 38 35
1 38 34
C - future_fif_digital_days_open_c

Time Limit: 2 sec / Memory Limit: 1024 MB

A,B,Cの3つの問題はテストケース数と入力の生成方法のみが異なります。共通部分はA問題を参照下さい。

テストケース数

50 個

入力生成方法

K=100B=10 で固定する。 印の座標は、まだ印の付いていない座標の中から一様ランダムに選択することで生成する。 ただし、1つ目の印は上端 (i_1=0)、2つ目の印は左端 (j_2=0)、3つ目の印は下端 (i_3=N-1)、4つ目の印は右端 (j_4=N-1) の中に絞り込んで一様ランダムに選択する。

各ポリオミノは以下のように生成する。 ポリオミノを構成する各正方形をブロックと呼ぶことにする。 1つ目のポリオミオは1ブロックからなり、コストはC_1=15とする。 b (2\leq b\leq B) 番目のポリオミノは 2(3+b) ブロックからなり、コストは C_b=\mathrm{round}(15\sqrt{2(3+b)}) で、1ブロックのポリオミノから開始して以下の拡張操作を 2(3+b)-1 回繰り返すことで生成する。

  1. 拡張する方向を上下左右の4方向の中から一様ランダムに選択する。
  2. その方向に向かって一番端にあるブロックの中から一様ランダムに選択し、その方向に隣接するマスをポリオミノに含めることで1ブロック拡張する。

入力例 1

50 100 10
0 25
1 0
49 21
49 49
0 43
41 9
26 6
5 26
12 32
38 33
13 4
16 7
17 28
41 14
36 28
16 11
2 46
25 18
40 46
33 42
5 9
17 45
27 23
26 48
9 14
6 22
29 37
17 11
12 42
0 32
46 40
7 43
35 27
30 33
3 40
34 14
7 20
37 32
12 38
4 41
28 17
16 46
36 29
29 35
41 21
26 14
28 5
22 7
0 24
25 10
19 22
45 15
16 19
46 2
40 39
8 34
46 19
33 29
2 35
29 46
16 43
49 39
21 34
12 0
25 49
33 30
20 9
35 42
19 15
24 35
24 30
8 5
45 4
37 38
46 20
16 45
15 5
45 49
4 2
18 45
37 8
13 49
13 32
28 26
41 6
42 3
17 43
21 16
14 13
0 33
15 24
11 32
11 15
16 30
20 12
26 38
0 19
23 0
29 30
46 22
1 1 15
#
8 3 47
..#
..#
..#
###
..#
..#
..#
..#
6 7 52
....#..
#######
.#.....
.#.....
.#.....
.#.....
8 7 56
......#
#######
...#...
...#...
...#...
...#...
...#...
...#...
5 12 60
.......#....
.......#####
########....
.....#......
.....#......
13 6 64
...#..
...#..
...#..
...#..
...#..
...#..
...###
####..
...#..
...#..
...#..
...#..
...#..
10 11 67
.........#.
.........#.
.........#.
.........#.
##########.
.........##
.........#.
.........#.
.........#.
.........#.
13 10 70
...#......
...#......
####......
...##.....
....#.....
....#.....
....#.....
....###...
......#...
......#...
......####
......#...
......#...
10 15 73
..........#....
..........#....
..........#....
..........#####
###########....
........#......
........#......
........#......
........#......
........#......
12 15 76
........#......
........#......
........#......
........#......
........#......
........#......
........#......
#########......
........#######
........#......
........#......
........#......

出力例 1

392
1 0 25
1 0 24
1 12 32
1 13 32
1 11 32
1 36 28
1 36 29
1 16 11
1 17 11
1 17 45
1 16 45
1 18 45
1 0 32
1 0 33
1 16 46
1 46 19
1 46 20
1 33 29
1 33 30
1 16 43
1 17 43
1 38 33
1 37 33
1 37 32
1 35 28
1 35 27
1 33 42
1 34 42
1 35 42
1 16 44
1 26 48
1 25 48
1 25 49
1 29 37
1 29 36
1 29 35
1 3 40
1 3 41
1 4 41
1 46 21
1 46 22
1 41 9
1 41 8
1 41 7
1 41 6
1 26 6
1 26 5
1 27 5
1 28 5
1 13 4
1 13 5
1 14 5
1 15 5
1 16 7
1 15 7
1 15 6
1 17 28
1 16 28
1 16 29
1 16 30
1 9 14
1 9 15
1 10 15
1 11 15
1 6 22
1 6 21
1 6 20
1 7 20
1 30 33
1 29 33
1 29 34
1 34 28
1 33 28
1 46 2
1 45 2
1 45 3
1 45 4
1 20 9
1 20 10
1 20 11
1 20 12
1 19 15
1 19 16
1 20 16
1 21 16
1 49 21
1 48 21
1 47 21
1 49 49
1 48 49
1 47 49
1 46 49
1 45 49
1 16 8
1 16 9
1 16 10
1 15 11
1 14 11
1 14 12
1 14 13
1 25 18
1 25 17
1 26 17
1 27 17
1 28 17
1 27 23
1 27 24
1 27 25
1 27 26
1 28 26
1 28 37
1 27 37
1 26 37
1 26 38
1 18 11
1 19 11
1 12 42
1 12 41
1 12 40
1 12 39
1 12 38
1 46 40
1 46 39
1 47 39
1 48 39
1 49 39
1 29 32
1 29 31
1 29 30
1 36 32
1 36 31
1 36 30
1 22 7
1 21 7
1 20 7
1 20 8
1 40 39
1 39 39
1 38 39
1 37 39
1 37 38
1 2 35
1 1 35
1 0 35
1 0 34
1 21 34
1 21 35
1 22 35
1 23 35
1 24 35
1 32 30
1 31 30
1 30 30
1 19 14
1 19 13
1 19 12
1 44 3
1 43 3
1 42 3
1 41 5
1 41 4
1 41 3
1 1 0
1 1 1
1 1 2
1 2 2
1 3 2
1 4 2
1 0 43
1 0 44
1 0 45
1 0 46
1 1 46
1 2 46
1 41 10
1 41 11
1 41 12
1 41 13
1 41 14
1 40 8
1 39 8
1 38 8
1 37 8
1 25 6
1 24 6
1 23 6
1 22 6
1 25 7
1 25 8
1 25 9
1 25 10
1 5 26
1 5 25
1 5 24
1 5 23
1 5 22
1 12 4
1 12 3
1 12 2
1 12 1
1 12 0
1 41 15
1 42 15
1 43 15
1 44 15
1 45 15
1 26 16
1 26 15
1 26 14
1 26 47
1 26 46
1 27 46
1 28 46
1 29 46
1 12 43
1 13 43
1 14 43
1 15 43
1 7 43
1 6 43
1 5 43
1 4 43
1 4 42
1 25 37
1 24 37
1 24 36
1 24 17
1 23 17
1 22 17
1 21 17
1 0 23
1 0 22
1 0 21
1 0 20
1 0 19
1 45 16
1 45 17
1 45 18
1 45 19
1 8 34
1 8 33
1 8 32
1 9 32
1 10 32
1 24 34
1 24 33
1 24 32
1 24 31
1 24 30
1 13 31
1 13 30
1 14 30
1 15 30
1 28 27
1 28 28
1 28 29
1 28 30
1 13 13
1 12 13
1 11 13
1 11 14
1 1 22
1 2 22
1 3 22
1 4 22
1 1 43
1 2 43
1 3 43
1 12 33
1 12 34
1 12 35
1 12 36
1 12 37
1 37 34
1 37 35
1 37 36
1 37 37
1 11 4
1 10 4
1 9 4
1 8 4
1 8 5
1 15 28
1 15 27
1 15 26
1 15 25
1 15 24
1 11 43
1 10 43
1 9 43
1 8 43
1 2 40
1 2 39
1 2 38
1 2 37
1 2 36
1 13 44
1 13 45
1 13 46
1 13 47
1 13 48
1 13 49
1 41 21
1 42 21
1 43 21
1 44 21
1 45 21
1 19 22
1 18 22
1 17 22
1 16 22
1 16 21
1 16 20
1 16 19
1 15 22
1 15 23
1 35 41
1 35 40
1 35 39
1 36 39
1 0 26
1 0 27
1 0 28
1 0 29
1 0 30
1 0 31
1 40 14
1 39 14
1 38 14
1 37 14
1 36 14
1 35 14
1 34 14
1 27 18
1 27 19
1 27 20
1 27 21
1 27 22
1 40 46
1 40 45
1 40 44
1 40 43
1 40 42
1 40 41
1 40 40
1 5 9
1 5 8
1 5 7
1 5 6
1 5 5
1 6 5
1 7 5
1 45 39
1 44 39
1 43 39
1 42 39
1 41 39
1 16 18
1 16 17
1 16 16
1 17 16
1 18 16
1 4 5
1 4 4
1 4 3
1 40 47
1 40 48
1 40 49
1 41 49
1 42 49
1 43 49
1 44 49
1 26 39
1 26 40
1 26 41
1 26 42
1 26 43
1 26 44
1 26 45
1 33 14
1 32 14
1 31 14
1 30 14
1 29 14
1 28 14
1 27 14
1 23 5
1 23 4
1 23 3
1 23 2
1 23 1
1 23 0