반응형
01-27 05:03
- Today
- Total
Link
개발하는 고라니
[Programmers] 섬 연결하기 본문
반응형
[Minimum Spanning Tree(MST), Kruskal 사용]
시작 정점, 도착 정점, 가중치 이렇게 3개의 멤버변수를 갖는 클래스 Edge를 선언하고 sort()를 이용하기 위해 Comparable 인터페이스를 구현한다.
static class Edge implements Comparable<Edge>{
int h, tg, d;
public Edge(int home, int target, int dist){
h=home;
tg=target;
d=dist;
}
@Override
public int compareTo(Edge o) {
return d-o.d;
}
}
Union-Find에 필요한 준비물들을 준비해주면 거의 끝난다.
static int[] parent = new int[101];
static int getParent(int x){
if(parent[x] == x) return x;
return parent[x] = getParent(parent[x]);
}
static boolean findParent(int a, int b){
a = getParent(a);
b = getParent(b);
return a == b? true: false;
}
static void union(int a, int b){
a = getParent(a);
b = getParent(b);
if(a < b) parent[b] = a;
else parent[a] = b;
}
인자로 받은 costs[][]에서 시작 정점, 도착 정점, 가중치를 List<Edge>에 담고 가중치를 기준으로 정렬 시킨 후 크루스칼 알고리즘을 사용하여 모든 정점을 연결하는 최소비용을 구한다.
# Code </>
package org.gorany.programmers.섬연결하기;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
public class Solution {
static class Edge implements Comparable<Edge>{
int h, tg, d;
public Edge(int home, int target, int dist){
h=home;
tg=target;
d=dist;
}
@Override
public int compareTo(Edge o) {
return d-o.d;
}
}
static List<Edge> list = new ArrayList<>();
static int[] parent = new int[101];
static int getParent(int x){
if(parent[x] == x) return x;
return parent[x] = getParent(parent[x]);
}
static boolean findParent(int a, int b){
a = getParent(a);
b = getParent(b);
return a == b? true: false;
}
static void union(int a, int b){
a = getParent(a);
b = getParent(b);
if(a < b) parent[b] = a;
else parent[a] = b;
}
public static int solution(int n, int[][] costs) {
for(int i=1; i<=n; i++)
parent[i] = i;
for(int i=0; i<costs.length; i++){
int home = costs[i][0];
int target = costs[i][1];
int dist = costs[i][2];
list.add(new Edge(home, target, dist));
list.add(new Edge(target, home, dist));
}
Collections.sort(list);
int answer = 0;
for(Edge e : list)
if(!findParent(e.h, e.tg)){
answer += e.d;
union(e.h, e.tg);
}
return answer;
}
/*
public static void main(String[] args) {
int n = 4;
int[][] costs = {{0,1,1},{0,2,2},{1,2,5},{1,3,1},{2,3,8}};
System.out.println(solution(n, costs));
}
*/
}
반응형
'Programming > 프로그래머스' 카테고리의 다른 글
[Programmers] 순위 (0) | 2021.03.28 |
---|---|
[Programmers] 가장 먼 노드 (0) | 2021.03.28 |
[Programmers] 문자열 내 마음대로 정렬하기 (0) | 2021.03.17 |
[Programmers] 지형 이동 (0) | 2021.03.10 |
[Programmers] 크레인 인형 뽑기 게임 (0) | 2021.02.06 |
Comments