提出 #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
結果
AC × 9
WA × 14
セット名 テストケース
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