結果
問題 |
No.74 貯金箱の退屈
|
ユーザー |
|
提出日時 | 2014-11-25 18:30:02 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
WA
|
実行時間 | - |
コード長 | 622 bytes |
コンパイル時間 | 377 ms |
コンパイル使用メモリ | 12,416 KB |
実行使用メモリ | 10,624 KB |
最終ジャッジ日時 | 2025-01-02 21:54:27 |
合計ジャッジ時間 | 2,295 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 17 WA * 13 |
ソースコード
n=int(input()) d=map(int,input().split()) w=map(int,input().split()) uf=list(range(n)) rv=[False]*n def find(n): if n==uf[n]: return n else: uf[n]=find(uf[n]) return uf[n] def union(a,b): uf[find(a)]=find(b) for i,di in enumerate(d): union((i+di)%n,(i-di)%n) if (i+di)%n==(i-di)%n: rv[(i+di)%n]=True for i,b in enumerate(rv): if b: rv[find(i)]=True for i in set(uf): cnt=0 for n,wi in enumerate(w): if uf[n]==i and wi==0: cnt+=1 if not rv[i] and cnt%2!=0: print("No") break else: print("Yes")