結果
問題 | No.2826 Earthwork |
ユーザー |
![]() |
提出日時 | 2024-07-26 17:13:41 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 4,560 ms / 5,000 ms |
コード長 | 2,206 bytes |
コンパイル時間 | 466 ms |
コンパイル使用メモリ | 82,012 KB |
実行使用メモリ | 387,664 KB |
最終ジャッジ日時 | 2024-07-26 17:15:40 |
合計ジャッジ時間 | 78,906 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 40 |
ソースコード
import heapqn=int(input())h=[list(map(int,input().split())) for i in range(n)]s=[input() for i in range(n)]a=[list(map(int,input().split())) for i in range(n-1)]b=[list(map(int,input().split())) for i in range(n)]q=int(input())rce=[tuple(map(int,input().split())) for i in range(q)]INF=int(4e18)def to(i,j):return i*n+jmx=[-INF]*n*nfor t in range(2):g=[[] for i in range(n*n+1)]for i in range(n-1):for j in range(n):p=h[i][j]+h[i+1][j]l=-p-a[i][j]*abs(p)r=-p+a[i][j]*abs(p)if (i+j)%2==t:g[to(i,j)].append((to(i+1,j),-l))g[to(i+1,j)].append((to(i,j),r))else:g[to(i,j)].append((to(i+1,j),r))g[to(i+1,j)].append((to(i,j),-l))for i in range(n):for j in range(n-1):p=h[i][j]+h[i][j+1]l=-p-b[i][j]*abs(p)r=-p+b[i][j]*abs(p)if (i+j)%2==t:g[to(i,j)].append((to(i,j+1),-l))g[to(i,j+1)].append((to(i,j),r))else:g[to(i,j)].append((to(i,j+1),r))g[to(i,j+1)].append((to(i,j),-l))for i in range(n):for j in range(n):if s[i][j]=='=' or s[i][j]=='-':if (i+j)%2==t:g[n*n].append((to(i,j),0))else:g[to(i,j)].append((n*n,0))if s[i][j]=='=' or s[i][j]=='+':if (i+j)%2==t:g[to(i,j)].append((n*n,0))else:g[n*n].append((to(i,j),0))dist=[INF]*(n*n+1)dist[n*n]=0hq=[(0,n*n)]heapq.heapify(hq)while hq:d,i=heapq.heappop(hq)if d!=dist[i]:continuefor ti,td in g[i]:if dist[i]+td<dist[ti]:dist[ti]=dist[i]+tdheapq.heappush(hq,(dist[ti],ti))for i in range(n):for j in range(n):if (i+j)%2==t:mx[to(i,j)]=max(mx[to(i,j)],h[i][j]+dist[to(i,j)])for r,c,e in rce:r-=1c-=1if e<=mx[to(r,c)]:print("Yes")else:print("No")