結果
| 問題 |
No.2316 Freight Train
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2023-05-26 21:33:12 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 663 ms / 2,000 ms |
| コード長 | 688 bytes |
| コンパイル時間 | 572 ms |
| コンパイル使用メモリ | 82,304 KB |
| 実行使用メモリ | 107,520 KB |
| 最終ジャッジ日時 | 2024-12-25 05:16:50 |
| 合計ジャッジ時間 | 16,211 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 26 |
ソースコード
n,q=map(int,input().split())
L=list(map(int,input().split()))
Q=[list(map(int,input().split())) for _ in range(q)]
import sys
sys.setrecursionlimit(10**8)
par=[i for i in range(n+1)]
rank=[0]*(n+1)
def find(x):
if par[x]==x:
return x
else:
par[x]=find(par[x])
return par[x]
def same(x,y):
return find(x)==find(y)
def unit(x,y):
x=find(x)
y=find(y)
if x==y:
return 0
if rank[x]<rank[y]:
par[x]=y
else:
par[y]=x
if rank[x]==rank[y]:
rank[x]+=1
for i in range(1,1+n):
if L[i-1]==-1:
L[i-1]=i
for i in range(1,1+n):
if L[i-1]!=i:
unit(i,L[i-1])
for a,b in Q:
if same(a,b):
print("Yes")
else:
print("No")