結果
問題 |
No.2914 正閉路検出
|
ユーザー |
👑 |
提出日時 | 2024-01-03 10:56:11 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
AC
|
実行時間 | 1,743 ms / 2,000 ms |
コード長 | 719 bytes |
コンパイル時間 | 259 ms |
コンパイル使用メモリ | 12,800 KB |
実行使用メモリ | 69,888 KB |
最終ジャッジ日時 | 2024-07-19 18:49:07 |
合計ジャッジ時間 | 39,011 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 55 |
コンパイルメッセージ
Main.py:34: SyntaxWarning: invalid decimal literal exit(O(*(P[-1::-1]if W<0else P)))
ソースコード
O,R=print,range J=lambda:map(int,input().split()) N,M=J() D=[[]for i in R(N)] E=[] p,h=list(R(N)),[0]*N w=h[:] def r(i): m=p[i] while m!=p[m]: w[i]+=w[m] m=p[i]=p[m] return m for j in R(M): A,B,W=map(int,input().split());A-=1;B-=1 a,b=r(A),r(B) E+=[[A,B,W]] if a==b: if w[A]-w[B]!=W: P,S,F=[j+1],[A],[0]*N while F[B]<1: i=S.pop() for[e,m]in D[i]: if F[e]<1: F[e],p[e]=1,m S+=[e] while A!=B: m=p[B] P+=[m+1] if B==E[m][0]:B,W=E[m][1],W+E[m][2] else:B,W=E[m][0],W-E[m][2] O(len(P)) O(A+1) exit(O(*(P[-1::-1]if W<0else P))) else: W=w[B]+W-w[A] if h[b]<h[a]:a,b,W=b,a,-W if h[a]==h[b]:h[b]+=1 p[a],w[a]=b,W D[A]+=[[B,j]] D[B]+=[[A,j]] O(-1)