c언어 1717번 집합의 표현 (백준)
#include #include int find(int parent[], int x) { //노드가 속한 부분집합의 대표노드 찾기 if(parent[x] == x) return x; //자기자신이면 자기자신을 리턴 return parent[x] = find(parent, parent[x]); //자기자신이 아니면, 부분집합의 대표노드의 대표노드 찾기 } void merge(int parent[], int x, int y) { //두개의 노드가 속한 집합 합치기 x = find(parent, x); //x의 대표 노드//사실 노드를 합치면 알아서 그 두개의 집합이 연결된다. y = find(parent, y); //y의 대표노드 if(x==y); //같은 노드이면 이미 같은 집합이다. else parent..
c언어/BAEKJOON
2023. 3. 19. 01:42
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- C언어
- 플로이드
- 카드
- 6198
- union
- 최대공약수
- 그래프
- C++
- BFS
- 덱
- 백준
- 세그먼트 트리
- 스택
- DP
- Krustal
- java
- 누적합
- DFS
- Mo.s
- 16120번
- 6198번
- 최소 스패닝 트리
- 트리
- 1835
- find
- 그리디
- 오프라인 쿼리
- 누적 합
- 1835번
- 정렬
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
글 보관함