結果

問題 No.1473 おでぶなおばけさん
ユーザー Navier_Boltzmann
提出日時 2021-11-28 19:11:51
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 1,186 ms / 2,000 ms
コード長 778 bytes
コンパイル時間 175 ms
コンパイル使用メモリ 82,132 KB
実行使用メモリ 121,344 KB
最終ジャッジ日時 2024-07-01 14:05:47
合計ジャッジ時間 21,377 ms
ジャッジサーバーID
(参考情報)
judge2 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2
other AC * 47
権限があれば一括ダウンロードができます

ソースコード

diff #

from collections import defaultdict,deque
import sys
sys.setrecursionlimit(10**6)

N,M = map(int,input().split())
e = defaultdict(list)
for _ in range(M):
    s,t,d = map(int,input().split())
    s -= 1
    t -= 1
    e[s].append((d,t))
    e[t].append((d,s))
    
v = deque()

def is_ok(x):
    dist = [-1]*N
    dist[0] = 0
    v.append(0)
    while v:
        ix = v.popleft()
        
        for d,jx in e[ix]:
            if dist[jx] != -1:
                continue
            if d>=x:
                dist[jx] = dist[ix] + 1
                v.append(jx)
    if dist[N-1] == -1:
        return False
    else:
        return dist[N-1]
        
x = 0
y = 10**10
while y-x>1:
    mid = (y+x)//2
    if is_ok(mid):
        x = mid
    else:
        y = mid
print(x,is_ok(x))
0