結果

問題 No.2712 Play more!
ユーザー sasa8uyauya
提出日時 2024-04-05 14:48:22
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 521 ms / 2,000 ms
コード長 562 bytes
コンパイル時間 323 ms
コンパイル使用メモリ 82,388 KB
実行使用メモリ 79,264 KB
最終ジャッジ日時 2024-10-01 01:07:55
合計ジャッジ時間 6,806 ms
ジャッジサーバーID
(参考情報)
judge2 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 33
権限があれば一括ダウンロードができます

ソースコード

diff #

n,m=map(int,input().split())
a=list(map(int,input().split()))
e=[]
for i in range(m):
  x,y,z=map(int,input().split())
  x-=1
  y-=1
  e+=[(x,y,z-a[x])]
X=10**20
v=[X]*n
v[0]=0
for i in range(n):
  p=[]
  f=0
  for x,y,z in e:
    if v[y]>v[x]+z:
      v[y]=v[x]+z
      f=1
      p+=[y]
if f==0:
  print(-v[-1]+a[-1])
else:
  E=[[] for i in range(n)]
  for x,y,z in e:
    E[x]+=[y]
  q=[]
  u=[0]*n
  for s in p:
    q+=[s]
    v[s]=1
  for s in q:
    for t in E[s]:
      if u[t]==0:
        u[t]=1
        q+=[t]
  print(-v[-1]+a[-1] if u[-1]==0 else "inf")
0