https://www.acmicpc.net/problem/1765
유니온 파인드를 사용하지 않고 친구의 친구도 반복문을 돌았을 때는 시간초과가 발생했다.
그래서, 원수의 원수의 경우에만 친구로 설정하고 친구의 경우는 유니온 파인드를 적용하여
친구를 구별하기로 했고 그렇게 했을 때는 시간 초과가 발생하지 않았다.
전역 클래스에 `equals`와 `hashCode` 메소드를 직접 작성했는데 다른 분들의 코드를 보면
굳이 이렇게 까지 작성하지 않아도 되는 거 같긴하다.
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.*;
public class BOJ1765 {
static class Node{
int end;
int kind;
public Node(int end, int kind){
this.end = end;
this.kind = kind;
}
@Override
public boolean equals(Object obj){
Node n = (Node) obj;
return this.end == n.end && this.kind == n.kind;
}
@Override
public int hashCode(){
return Objects.hash(end, kind);
}
}
static class Info{
int start;
int end;
public Info(int start, int end){
this.start = start;
this.end = end;
}
@Override
public boolean equals(Object obj){
Info i = (Info) obj;
return this.end == i.end && this.start == i.start;
}
@Override
public int hashCode(){
return Objects.hash(start, end);
}
}
static int[] parent;
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int N = Integer.parseInt(br.readLine());
int M = Integer.parseInt(br.readLine());
parent = new int[N + 1];
List<Set<Node>> graph = new ArrayList<>();
for(int i = 0; i <= N; i++){
graph.add(new HashSet<>());
if(i >= 1){
parent[i] = i;
}
}
StringTokenizer st;
for(int i = 0; i < M; i++){
st = new StringTokenizer(br.readLine());
String kind = st.nextToken();
int start = Integer.parseInt(st.nextToken());
int end = Integer.parseInt(st.nextToken());
if(kind.equals("E")){
graph.get(start).add(new Node(end, -1));
graph.get(end).add(new Node(start, - 1));
} else{
graph.get(start).add(new Node(end, 1));
graph.get(end).add(new Node(start, 1));
}
}
for(int i = 1; i <= N; i++){
Set<Info> result = new HashSet<>();
for(Node node : graph.get(i)){
if(node.kind == -1){
for(Node n : graph.get(node.end)){
if(n.kind == -1 && i != n.end){
result.add(new Info(i, n.end));
// graph.get(i).add(new int[]{arr[0], 1});
result.add(new Info(n.end, i));
}
}
}
}
for(Info info : result){
graph.get(info.start).add(new Node(info.end, 1));
}
}
// for(int i = 1; i <= N; i++){
// for(Node node : graph.get(i)){
// System.out.println(node.end + " " + node.kind);
// }
// System.out.println();
// }
for(int i = 1; i <= N; i++){
for(Node node : graph.get(i)){
if(node.kind == 1 && parent[i] != parent[node.end]){
union(i, node.end);
}
}
}
Set<Integer> set = new HashSet<>();
for(int i = 1; i <= N; i++){
set.add(parent[i]);
}
System.out.println(set.size());
}
public static void union(int a, int b){
a = find_parent(a);
b = find_parent(b);
if(a < b){
parent[b] = a;
} else{
parent[a] = b;
}
}
public static int find_parent(int p){
if(parent[p] == p){
return p;
}
parent[p] = find_parent(parent[p]);
return parent[p];
}
}
'PS > 백준' 카테고리의 다른 글
[백준] 풍성한 트리 - Java 32934 (0) | 2024.12.24 |
---|---|
[백준] 콘센트 - Java 23843 (0) | 2024.10.24 |
[백준] 트럭 - Java 13335 (0) | 2024.10.24 |
[백준] 우주 탐사선 - Java 17182 (0) | 2024.10.21 |
[백준] 램프 - Java 1034 (0) | 2024.10.10 |