알고리즘/문제

[Union-Find] 백준 10775 공항

_Min 2021. 3. 2. 19:45

 

 

문제링크 www.acmicpc.net/problem/10775

 

 

고통의 시간을 거치고 드디어 맞았다!! 🎉👏🎉👏

 

 

 

[답코드]

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
import sys
input=sys.stdin.readline
sys.setrecursionlimit(10**6# 최대 재귀 깊이 제한 늘림
 
# 특정 원소가 속한 집합을 찾기
def find_parent(parent, x):
    # 루트 노드가 아니라면, 루트 노드를 찾을 때까지 재귀적으로 호출
    if parent[x] != x:
        parent[x] = find_parent(parent, parent[x])
    return parent[x]
 
# 두 원소가 속한 집합을 합치기
def union_parent(parent, a):
    a = find_parent(parent, a)
    b = a-1
    if b<0:
        return -1
    if a < b:
        parent[b] = a
    else:
        parent[a] = b
    return 0
 
# 노드의 개수와 간선(Union 연산)의 개수 입력 받기
v=int(input())
e=int(input())
parent = [0* (v + 1# 부모 테이블 초기화하기
 
# 부모 테이블상에서, 부모를 자기 자신으로 초기화
for i in range(1, v + 1):
    parent[i] = i
 
result=0
# Union 연산을 각각 수행
for i in range(e):
    a=int(input())
    if union_parent(parent, a)<0:
        break
    result += 1
 
print(result)
cs

 

 

 

[풀이법]

 

최대 재귀 깊이 늘리기

파이썬은 재귀 호출 제한이 1000번까지라고 한다. 이를 늘려줘야 런타임 에러가 안 난다

 

 

 

 

② 흐름

 

입력값이 들어오면 union_parent를 진행한다.

입력값 a의 parent 노드를 찾아 (a의 parent노드)와 (a의 parent노드-1)을 합쳐준다

여기서 parent에 입력할 숫자의 범위는 0까지여야 하므로 b값이 0미만이면 break 한다

 

 

 

 

③ 출력(예제1)

 

입력값 4
3
4
1
1

 

초기화
입력 4, union(4, 3)
입력 1, union(1, 0)
입력 1, union(0, -1) break *b가 0 미만

 

 

 

 

출력(예제2)

입력값 4
6
2
2
3
3
4
4

 

초기화
입력 2, union(2, 1)
입력 2, union(1, 0)
입력 3, union(3, 1)
입력 3, union(0, -1) break *b가 0 미만

 

728x90