結果
問題 | No.179 塗り分け |
ユーザー |
![]() |
提出日時 | 2017-07-27 23:20:05 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
AC
|
実行時間 | 1,262 ms / 3,000 ms |
コード長 | 1,005 bytes |
コンパイル時間 | 141 ms |
コンパイル使用メモリ | 12,800 KB |
実行使用メモリ | 11,136 KB |
最終ジャッジ日時 | 2024-07-23 14:44:01 |
合計ジャッジ時間 | 9,646 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 6 |
other | AC * 40 |
ソースコード
H,W = list(map(int, input().split(' '))) blacks = {} for h in range(H): boxes = input() for w in range(W): if boxes[w] == '#': blacks[(h,w)] = 0 if len(blacks) == 0 or len(blacks) % 2 != 0: print('NO') exit() def check(i, j): yes = True for key in blacks.keys(): blacks[key] = 0 for (h,w) in sorted(blacks.keys()): if blacks[(h,w)] == 0: blacks[(h,w)] = 1 if (h+i,w+j) not in blacks: yes = False break else: blacks[(h+i,w+j)] = 1 if yes: print('YES') exit() # check from top to bottom for i in range(1,H): check(i, 0) # check from left to right for j in range(1,W): check(0, j) # check from upper left to lower right for i in range(1,H): for j in range(1,W): check(i, j) # check from upper right to lower left for i in range(1,H): for j in range(1,W): check(i, -j) print('NO')