結果
問題 |
No.971 いたずらっ子
|
ユーザー |
|
提出日時 | 2020-04-15 21:31:12 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 1,725 ms / 2,000 ms |
コード長 | 970 bytes |
コンパイル時間 | 502 ms |
コンパイル使用メモリ | 82,560 KB |
実行使用メモリ | 315,264 KB |
最終ジャッジ日時 | 2024-11-07 11:44:37 |
合計ジャッジ時間 | 14,567 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 21 |
ソースコード
INF = 10 ** 7 import sys input = sys.stdin.readline sys.setrecursionlimit(100000000) dy = (-1,0,1,0) dx = (0,1,0,-1) from collections import deque def main(): h,w = map(int,input().split()) grid = [list(input()) for _ in range(h)] q = deque() q.append((0,0)) dist = [[INF] * w for _ in range(h)] dist[0][0] = 0 while q: i,j = q.popleft() for k in range(1,3): y = i + dy[k] x = j + dx[k] if y < 0 or y >= h: continue if x < 0 or x >= w: continue if grid[y][x] == 'k': if dist[y][x] > dist[i][j] + 1 + y + x: dist[y][x] = dist[i][j] + 1 + y + x q.append((y,x)) else: if dist[y][x] > dist[i][j] + 1: dist[y][x] = dist[i][j] + 1 q.append((y,x)) print(dist[-1][-1]) if __name__ == '__main__': main()