코딩테스트/python
백준_20040_사이클 게임
zyin
2022. 4. 3. 12:11
문제
https://www.acmicpc.net/problem/20040
20040번: 사이클 게임
사이클 게임은 두 명의 플레이어가 차례대로 돌아가며 진행하는 게임으로, 선 플레이어가 홀수 번째 차례를, 후 플레이어가 짝수 번째 차례를 진행한다. 게임 시작 시 0 부터 n − 1 까지 고유한
www.acmicpc.net
풀이
분리집합
이미 같은 집합에 있는 원소(부모가 같은 원소)들이 언급되었다면, 사이클이 생긴 것이다.
코드
def find(n) :
if parent[n]==n : return n
parent[n] = find(parent[n])
return parent[n]
def union(x, y) :
x = find(x)
y = find(y)
if x<=y : parent[x] = y
else : parent[y] = x
def main(n, m, arr) :
for i, (x, y) in enumerate(arr) :
if find(x)==find(y) : return i+1
union(x, y)
return 0
import sys
sys.setrecursionlimit(10**6)
input = sys.stdin.readline
n, m = map(int, input().strip().split())
parent = [i for i in range(n)]
arr = [map(int, input().strip().split()) for i in range(m)]
print(main(n, m, arr))