結果
問題 | No.20 砂漠のオアシス |
ユーザー | yuma25689 |
提出日時 | 2015-10-31 03:47:58 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
AC
|
実行時間 | 424 ms / 5,000 ms |
コード長 | 4,163 bytes |
コンパイル時間 | 244 ms |
コンパイル使用メモリ | 12,928 KB |
実行使用メモリ | 26,496 KB |
最終ジャッジ日時 | 2024-10-13 05:30:02 |
合計ジャッジ時間 | 3,686 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 30 ms
11,008 KB |
testcase_01 | AC | 30 ms
10,880 KB |
testcase_02 | AC | 30 ms
11,008 KB |
testcase_03 | AC | 45 ms
11,648 KB |
testcase_04 | AC | 47 ms
11,776 KB |
testcase_05 | AC | 320 ms
22,656 KB |
testcase_06 | AC | 419 ms
26,368 KB |
testcase_07 | AC | 421 ms
26,496 KB |
testcase_08 | AC | 320 ms
26,368 KB |
testcase_09 | AC | 424 ms
26,368 KB |
testcase_10 | AC | 31 ms
11,008 KB |
testcase_11 | AC | 31 ms
10,880 KB |
testcase_12 | AC | 44 ms
11,264 KB |
testcase_13 | AC | 48 ms
11,648 KB |
testcase_14 | AC | 60 ms
12,288 KB |
testcase_15 | AC | 52 ms
11,904 KB |
testcase_16 | AC | 103 ms
13,824 KB |
testcase_17 | AC | 80 ms
12,800 KB |
testcase_18 | AC | 86 ms
13,440 KB |
testcase_19 | AC | 99 ms
13,696 KB |
testcase_20 | AC | 38 ms
11,264 KB |
ソースコード
import sys import heapq INF=1e10 class Node: ''' このdijkstra法で使用するnode ''' def __init__(self,x,y,fc,tc,to): self.x=x self.y=y self.minFromCost=fc self.toCost=tc self.to=to self.done=False self.inQueue=False def __eq__(self,n): return self.x == n.x and self.y == n.y def __lt__(self,n): return self.minFromCost < n.minFromCost def clear(self): self.minFromCost=INF self.done=False def updateCostByDijkstra(firstNode,nodeList,targetNodes=None): ''' firstNodeからのnodeList内の全ノードに対して移動するのにかかるコストを取得 ただし、dijkstra法なので、0<=cost ''' queue=[] heapq.heapify(queue) heapq.heappush( queue, firstNode ) getTarget=False # cnt=0 while 0 < len(queue): # キューが空でない限り # キュー取り出し doneNode=heapq.heappop(queue) doneNode.done=True doneNode.inQueue=False # cnt+=1 # print(cnt) if targetNodes: getTarget=True for t in targetNodes: if not t.done: getTarget=False break if getTarget: return for i in doneNode.to: if nodeList[i].done==True: continue # 接続先ノードを更新 current = doneNode.minFromCost + nodeList[i].toCost if nodeList[i].minFromCost == INF or current < nodeList[i].minFromCost: nodeList[i].minFromCost = current if nodeList[i].inQueue == False: nodeList[i].inQueue = True # 参照渡しの必要あり。pythonではそれで普通かな? heapq.heappush( queue, nodeList[i] ) # else: # print( "in queue " + str(nodeList[i].x) + "," + str(nodeList[i].y) ) # print( "[" + str(doneNode.x) + "," + str(doneNode.y) + "]" + "->[" + str(nodeList[i].x) + "," + str(nodeList[i].y) \ # + "]"+"="+str(nodeList[i].minFromCost) + "(" + str(nodeList[i].toCost) +")") line=sys.stdin.readline() line1=line.split() edgeCount = int(line1[0]) HP=int(line1[1]) oasisPos=[int(line1[2]),int(line1[3])] damageOfPos=[[0 for i in range(edgeCount)] for j in range(edgeCount)] # 各点から目的地までの最小コスト for y in range(edgeCount): line=sys.stdin.readline() lineN=line.split() for x in range(edgeCount): damageOfPos[x][y]=int(lineN[x]) # Dijkstra #minFromCost=[[INF for i in range(edgeCount)]for j in range(edgeCount)] NextCoords=[(1,0),(0,1),(-1,0),(0,-1)] # nodeを作成 # 接続先情報も上下左右として作成する nodes=[] for x in range(edgeCount): for y in range(edgeCount): toNodeInduces=[] for i in range(len(NextCoords)): (dx,dy)=NextCoords[i] to_x=x+dx to_y=y+dy if 0 <=to_x<edgeCount and 0<=to_y<edgeCount: toNodeInduces.append( to_y + edgeCount*to_x ) nodes.append( Node(x,y,INF,damageOfPos[x][y],toNodeInduces) ) # 最初の点のコストを0に初期化 nodes[0].minFromCost=0 oasisIndex=-1 if not ( oasisPos[0]==0 and oasisPos[1]==0 ): oasisIndex=oasisPos[1]-1 + edgeCount*(oasisPos[0]-1) # 最初のnodeからdijkstra法 targets=[] targets.append(nodes[oasisIndex]) targets.append(nodes[len(nodes)-1]) updateCostByDijkstra(nodes[0],nodes,targets) # for node in nodes: # print( "[" + str(node.x) + "," + str(node.y) + "]="+str(node.minFromCost) ) if nodes[len(nodes)-1].minFromCost < HP: print('YES') sys.exit(0) # HPが足りなかった # print('HP{0} not enouph.cost{1}'.format( HP, nodes[len(nodes)-1].minFromCost) ) # オアシス経由でいけるか試す if oasisPos[0]==0 and oasisPos[1]==0: # print('not exist oasis') print('NO') sys.exit(0) # print('oasis exists [toCost]={}'.format( nodes[oasisIndex].minFromCost ) ) if nodes[oasisIndex].minFromCost < HP: HP = (HP-nodes[oasisIndex].minFromCost)*2 else: # print('cant reach oasis{} HP{}'.format( nodes[oasisIndex].minFromCost, HP)) print('NO') sys.exit(0) # print('HP recovery to {}'.format(HP)) # 最初の点をoasisにしてもう一度dijkstra for node in nodes: node.clear() nodes[oasisIndex].minFromCost=0 updateCostByDijkstra(nodes[oasisIndex],nodes,[nodes[len(nodes)-1]]) # for node in nodes: # print( "[" + str(node.x) + "," + str(node.y) + "]="+str(node.minFromCost) ) if nodes[len(nodes)-1].minFromCost < HP: print('YES') else: print('NO')