提出 #461831
ソースコード 拡げる
#! /usr/bin/env python
# -*- coding: utf-8 -*-
# http://lethe2211.hatenablog.com/entry/2014/12/30/011030
import heapq
class Dijkstra(object):
def dijkstra(self, adj, start, goal=None):
'''
ダイクストラアルゴリズムによる最短経路を求めるメソッド
入力
adj: adj[i][j]の値が頂点iから頂点jまでの距離(頂点iから頂点jに枝がない場合,値はfloat('inf'))となるような2次元リスト(正方行列)
start: 始点のID
goal: オプション引数.終点のID
出力
goalを引数に持つ場合,startからgoalまでの最短経路を格納したリストを返す
持たない場合は,startから各頂点までの最短距離を格納したリストを返す
>>> d = Dijkstra()
>>> d.dijkstra([[float('inf'), 2, 4, float('inf'), float('inf')], [2, float('inf'), 3, 5, float('inf')], [4, 3, float('inf'), 1, 4], [float('inf'), 5, 1, float('inf'), 3], [float('inf'), float('inf'), 4, 3, float('inf')]], 0)
[0, 2, 4, 5, 8] # 例えば,始点0から頂点3までの最短距離は5となる
>>> d.dijkstra([[float('inf'), 2, 4, float('inf'), float('inf')], [2, float('inf'), 3, 5, float('inf')], [4, 3, float('inf'), 1, 4], [float('inf'), 5, 1, float('inf'), 3], [float('inf'), float('inf'), 4, 3, float('inf')]], 0, goal=4)
[0, 2, 4] # 頂点0から頂点4までの最短経路は0 -> 2 -> 4となる
'''
num = len(adj) # グラフのノード数
dist = [float('inf') for i in range(num)] # 始点から各頂点までの最短距離を格納する
prev = [float('inf') for i in range(num)] # 最短経路における,その頂点の前の頂点のIDを格納する
dist[start] = 0
q = [] # プライオリティキュー.各要素は,(startからある頂点vまでの仮の距離, 頂点vのID)からなるタプル
heapq.heappush(q, (0, start)) # 始点をpush
while len(q) != 0:
prov_cost, src = heapq.heappop(q) # pop
# プライオリティキューに格納されている最短距離が,現在計算できている最短距離より大きければ,distの更新をする必要はない
if dist[src] < prov_cost:
continue
# 他の頂点の探索
for dest in range(num):
cost = adj[src][dest]
if cost != float('inf') and dist[dest] > dist[src] + cost:
dist[dest] = dist[src] + cost # distの更新
heapq.heappush(q, (dist[dest], dest)) # キューに新たな仮の距離の情報をpush
prev[dest] = src # 前の頂点を記録
if goal is not None:
return self.get_path(goal, prev)
else:
return dist
def get_path(self, goal, prev):
'''
始点startから終点goalまでの最短経路を求める
'''
path = [goal] # 最短経路
dest = goal
# 終点から最短経路を逆順に辿る
while prev[dest] != float('inf'):
path.append(prev[dest])
dest = prev[dest]
# 経路をreverseして出力
return list(reversed(path))
# main
inf = float('inf')
n = int(input())
d = {}
rd = {}
for i in range(n):
s = input()
d[s] = i
rd[i] = s
table = [[inf for i in range(n)] for j in range(n)]
for i in range(int(input())):
x, y = input().split()
table[d[x]][d[y]] = 1
table[d[y]][d[x]] = 1
start = input()
goal = input()
D = Dijkstra()
path1 = D.dijkstra(table, d[start], d[goal])
for i in range(len(path1)):
if i == 0:
continue
x, y = path1[i-1], path1[i]
table[x][y] = inf
table[y][x] = inf
path2 = D.dijkstra(table, d[goal], d[start])
s = rd[path1[0]]
g = rd[path1[-1]]
p1 = ''.join([rd[i] for i in path1[1:-1]])
p2 = ''.join([rd[i] for i in path2[1:-1]])
if p1 > p2:
p1, p2 = p2, p1
print(s + p1 + g + p2)
提出情報
| 提出日時 |
|
| 問題 |
D - 氷柱の上の聖剣 |
| ユーザ |
matsulib |
| 言語 |
Python (3.4.2) |
| 得点 |
0 |
| コード長 |
4265 Byte |
| 結果 |
WA |
| 実行時間 |
162 ms |
| メモリ |
7016 KiB |
ジャッジ結果
| セット名 |
All |
| 得点 / 配点 |
0 / 100 |
| 結果 |
|
| セット名 |
テストケース |
| All |
00_sample_00.txt, 00_sample_01.txt, 05_corner_00.txt, 05_corner_01.txt, 05_corner_02.txt, 10_min_00.txt, 10_min_01.txt, 10_min_02.txt, 10_wrong_answer_00.txt, 20_max_00.txt, 20_max_01.txt, 20_max_02.txt, 90_random_00.txt, 90_random_01.txt, 90_random_02.txt, 90_random_03.txt, 90_random_04.txt, 90_random_05.txt, 90_random_06.txt, 90_random_07.txt, 90_random_08.txt, 90_random_09.txt, 99_medium_00.txt |
| ケース名 |
結果 |
実行時間 |
メモリ |
| 00_sample_00.txt |
AC |
162 ms |
7012 KiB |
| 00_sample_01.txt |
AC |
108 ms |
7008 KiB |
| 05_corner_00.txt |
WA |
107 ms |
7008 KiB |
| 05_corner_01.txt |
AC |
109 ms |
7008 KiB |
| 05_corner_02.txt |
AC |
107 ms |
7012 KiB |
| 10_min_00.txt |
WA |
118 ms |
7008 KiB |
| 10_min_01.txt |
WA |
108 ms |
7012 KiB |
| 10_min_02.txt |
AC |
107 ms |
7008 KiB |
| 10_wrong_answer_00.txt |
WA |
107 ms |
7016 KiB |
| 20_max_00.txt |
WA |
113 ms |
7012 KiB |
| 20_max_01.txt |
WA |
109 ms |
7012 KiB |
| 20_max_02.txt |
WA |
110 ms |
7016 KiB |
| 90_random_00.txt |
AC |
109 ms |
6932 KiB |
| 90_random_01.txt |
AC |
111 ms |
6888 KiB |
| 90_random_02.txt |
AC |
111 ms |
7016 KiB |
| 90_random_03.txt |
WA |
109 ms |
7012 KiB |
| 90_random_04.txt |
WA |
108 ms |
7012 KiB |
| 90_random_05.txt |
WA |
108 ms |
6932 KiB |
| 90_random_06.txt |
WA |
112 ms |
7016 KiB |
| 90_random_07.txt |
WA |
108 ms |
7012 KiB |
| 90_random_08.txt |
WA |
107 ms |
7012 KiB |
| 90_random_09.txt |
WA |
107 ms |
7012 KiB |
| 99_medium_00.txt |
AC |
109 ms |
7004 KiB |