結果
問題 | No.20 砂漠のオアシス |
ユーザー | むらため |
提出日時 | 2019-10-12 16:02:08 |
言語 | Nim (2.0.2) |
結果 |
CE
(最新)
AC
(最初)
|
実行時間 | - |
コード長 | 1,523 bytes |
コンパイル時間 | 1,136 ms |
コンパイル使用メモリ | 66,264 KB |
最終ジャッジ日時 | 2024-11-14 21:44:40 |
合計ジャッジ時間 | 1,535 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
コンパイルエラー時のメッセージ・ソースコードは、提出者また管理者しか表示できないようにしております。(リジャッジ後のコンパイルエラーは公開されます)
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
ただし、clay言語の場合は開発者のデバッグのため、公開されます。
コンパイルメッセージ
/home/judge/data/code/Main.nim(28, 15) Error: undeclared identifier: 'newHeapQueue' candidates (edit distance, scope distance); see '--spellSuggest': (3, 2): 'heapqueue' (3, 4): 'initHeapQueue' (3, 4): 'toHeapQueue'
ソースコード
{.checks:off.} import sequtils,strutils,algorithm,heapqueue proc getchar_unlocked():char {. importc:"getchar_unlocked",header: "<stdio.h>" .} proc scan(): int = while true: let k = getchar_unlocked() if k < '0': break result = 10 * result + k.ord - '0'.ord template times*(n:int,body) = (for _ in 0..<n: body) template `max=`*(x,y)= (x = max(x,y)) template `min=`*(x,y)= (x = min(x,y)) const dxdy4 :seq[tuple[x,y:int]] = @[(0,1),(1,0),(0,-1),(-1,0)] let N = scan() let V = scan() let oax = scan() let oay = scan() var L = newSeq[seq[int]](N) for x in 0..<N: L[x] = newSeq[int](N) for y in 0..<N: L[x][y] = scan() let (ox,oy) = (oax-1,oay-1) ############## 二段階にわける ##################### type field = tuple[x,y,v:int] proc `<`(x,y:field):bool = (x.v > y.v) proc twoFactorDijkestra(sx,sy,sv:int,checkOasis:bool = true):void = var closed = newSeqWith(N,newSeqWith(N,false)) var opens = newHeapQueue[field]() opens.push((sx,sy,sv)) while opens.len() > 0: let (x,y,v) = opens.pop() if closed[x][y] : continue closed[x][y] = true if checkOasis and x == ox and y == oy: twoFactorDijkestra(x,y,v * 2,false) continue for d in dxdy4: let (nx,ny) = (d.x + x,d.y + y) if nx < 0 or ny < 0 or nx >= N or ny >= N : continue var n_v = v - L[ny][nx] if n_v <= 0 : continue if not closed[nx][ny]: opens.push((nx,ny,n_v)) if nx == N-1 and ny == N-1: echo "YES" quit() twoFactorDijkestra(0,0,V) echo "NO"