結果
問題 |
No.859 路線A、路線B、路線C
|
ユーザー |
![]() |
提出日時 | 2020-01-14 02:12:20 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
AC
|
実行時間 | 35 ms / 1,000 ms |
コード長 | 1,570 bytes |
コンパイル時間 | 334 ms |
コンパイル使用メモリ | 13,056 KB |
実行使用メモリ | 11,136 KB |
最終ジャッジ日時 | 2024-12-23 12:45:19 |
合計ジャッジ時間 | 1,616 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 12 |
ソースコード
def djkstra3(a,in_connect_list,v): out_shortest_list = [10**15 for i in range(v)] out_shortest_list[a] = 0 searching_list = [a] while searching_list != []: new_search_list = [] for i in searching_list: for c, d in in_connect_list[i]: if out_shortest_list[c] > d + out_shortest_list[i]: out_shortest_list[c] = d + out_shortest_list[i] new_search_list.append(c) searching_list = new_search_list return out_shortest_list x, y, z = [ int(v) for v in input().split() ] s0, t0 = input().split() s1, t1 = input().split() t0, t1 = int(t0), int(t1) connect_list = [ [] for i in range(8) ] d_list = (x, y, z) c_list = ("A", "B", "C") for i in range(3): for j in range(3): if i != j: connect_list[i].append((j, 1)) for i in range(3, 6): for j in range(3, 6): if i != j: connect_list[i].append((j, 1)) for i in range(3): connect_list[i].append((i+3, d_list[i]-1)) connect_list[i+3].append((i, d_list[i]-1)) i = c_list.index(s0) connect_list[i].append((6, t0-1)) connect_list[i+3].append((6, d_list[i]-t0)) connect_list[6].append((i, t0-1)) connect_list[6].append((i+3, d_list[i]-t0)) i = c_list.index(s1) connect_list[i].append((7, t1-1)) connect_list[i+3].append((7, d_list[i]-t1)) connect_list[7].append((i, t1-1)) connect_list[7].append((i+3, d_list[i]-t1)) distance_list = djkstra3(6,connect_list,8) d0 = distance_list[7] if s0 == s1: d1 = abs(t0 - t1) print(min(d0, d1)) else: print(d0)