0. disjoint set 문제
1. A에서 B로 선분을 그으려 할 때, 이미 A와 B가 같은 집합에 속한다면 사이클이 생성된다
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
public class Main{
public static void main(String[] args)throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine(), " ");
int n = pint(st.nextToken());
int m = pint(st.nextToken());
init(n);
for (int i = 0; i < m; i++) {
st = new StringTokenizer(br.readLine(), " ");
int x = pint(st.nextToken());
int y = pint(st.nextToken());
if(!union(x,y)) {
System.out.println(i+1);
break;
}
else if(i==m-1) {
System.out.println(0);
}
}
}
static int[] parents;
static void init(int n) {
parents=new int[n];
for (int i = 0; i < n; i++) {
parents[i]=i;
}
}
static int find(int n) {
if(parents[n]!=n)return parents[n]=find(parents[n]);
return n;
}
static boolean union(int x, int y) {
int px=find(x), py=find(y);
if(px==py)return false;
parents[px]=py;
return true;
}
static int pint(String s) {
return Integer.parseInt(s);
}
}
'알고리즘 문제 풀이 > BOJ 골드' 카테고리의 다른 글
[백준] 16724 - 피리 부는 사나이 (0) | 2021.05.16 |
---|---|
[백준] 1068 - 트리 (0) | 2021.05.14 |
[백준] 16946 - 벽 부수고 이동하기 4 (0) | 2021.05.13 |
[백준] 1062 - 가르침 (0) | 2021.05.05 |
[백준] 17404 - RGB거리 2 (0) | 2021.05.02 |
[백준] 10775 - 공항 (0) | 2021.05.01 |
[백준] 1939 - 중량제한 (0) | 2021.05.01 |