結果
| 問題 |
No.34 砂漠の行商人
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2022-02-10 13:54:26 |
| 言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
| 結果 |
MLE
|
| 実行時間 | - |
| コード長 | 801 bytes |
| コンパイル時間 | 206 ms |
| コンパイル使用メモリ | 12,800 KB |
| 実行使用メモリ | 799,488 KB |
| 最終ジャッジ日時 | 2024-06-25 20:10:48 |
| 合計ジャッジ時間 | 20,661 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 11 MLE * 3 -- * 12 |
ソースコード
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)