結果
| 問題 | No.2316 Freight Train |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2023-05-26 21:33:12 |
| 言語 | PyPy3 (7.3.17) |
| 結果 |
AC
|
| 実行時間 | 654 ms / 2,000 ms |
| コード長 | 688 bytes |
| 記録 | |
| コンパイル時間 | 230 ms |
| コンパイル使用メモリ | 85,504 KB |
| 実行使用メモリ | 113,792 KB |
| 最終ジャッジ日時 | 2026-05-30 22:31:58 |
| 合計ジャッジ時間 | 15,436 ms |
|
ジャッジサーバーID (参考情報) |
judge1_0 / judge2_1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| 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")