結果
| 問題 |
No.307 最近色塗る問題多くない?
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2016-10-03 15:07:13 |
| 言語 | Python2 (2.7.18) |
| 結果 |
RE
|
| 実行時間 | - |
| コード長 | 951 bytes |
| コンパイル時間 | 70 ms |
| コンパイル使用メモリ | 6,948 KB |
| 実行使用メモリ | 29,740 KB |
| 最終ジャッジ日時 | 2024-11-21 15:15:09 |
| 合計ジャッジ時間 | 51,358 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 16 RE * 13 TLE * 7 |
ソースコード
dr = [0, 0, 1, -1]
dc = [1, -1, 0, 0]
H, W = map(int, raw_input().split())
board = [map(int, raw_input().split()) for _ in xrange(H)]
Q = input()
queries = [map(int, raw_input().split()) for _ in xrange(Q)]
def dfs(r, c, color):
visited = set()
stack = [(r, c)]
while len(stack) > 0:
r, c = stack.pop()
if (r, c) in visited or board[r][c] == color:
continue
visited.add((r, c))
board[r][c] = color
for i in xrange(4):
nr, nc = r+dr[i], c+dc[i]
if nr < 0 or nr >= H or nc < 0 or nc >= W or (nr, nc) in visited:
continue
stack.append((nr, nc))
for q in queries:
dfs(q[0]-1, q[1]-1, q[2])
if all(all(board[0][0]==board[i][j] for j in xrange(W)) for i in xrange(H)):
for i in xrange(H):
print ' '.join([str(q[-1][2])]*W)
exit()
for i in xrange(H):
print ' '.join(map(str, board[i]))