結果
問題 |
No.34 砂漠の行商人
|
ユーザー |
|
提出日時 | 2022-02-10 13:54:42 |
言語 | PyPy3 (7.3.15) |
結果 |
MLE
|
実行時間 | - |
コード長 | 801 bytes |
コンパイル時間 | 287 ms |
コンパイル使用メモリ | 82,104 KB |
実行使用メモリ | 848,736 KB |
最終ジャッジ日時 | 2024-06-25 20:10:57 |
合計ジャッジ時間 | 8,755 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 9 MLE * 2 -- * 15 |
ソースコード
from collections import deque n,v,sx,sy,gx,gy=map(int,input().split()) sx-=1;sy-=1;gx-=1;gy-=1 grid=[list(map(int,input().split())) for _ in range(n)] inf=float('inf') dst=[[inf]*n for _ in range(n)] dy=[0,1,0,-1];dx=[1,0,-1,0] visited=[[[False]*(v+1) for _ in range(n)] for _ in range(n)] hp=[[0]*n for _ in range(n)] q=deque() q.append((0,sy,sx,v)) while q: d,y,x,h=q.popleft() if (y,x)==(gy,gx): print(d) exit() if visited[y][x][h]: continue visited[y][x][h]=True if hp[y][x]>=h: continue hp[y][x]=h for i in range(4): ny,nx=y+dy[i],x+dx[i] if 0<=ny<n and 0<=nx<n and h>grid[ny][nx]: nh=h-grid[ny][nx] if not visited[ny][nx][nh] and hp[ny][nx]<nh: q.append((d+1,ny,nx,nh)) print(-1)