Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- lcap
- 완전탐색
- 트리
- MySQL
- Mendix
- 집합
- 멘딕스
- SQL
- 재귀
- 알고리즘
- Bruteforce
- Recursion
- algorithm
- git
- 프로그래머스
- 가중치없는그래프
- microflow
- dfs
- 해시맵
- 매개변수 탐색
- 백트래킹
- 자바
- 이분탐색
- domain model
- 그래프
- 자료구조
- 반효경교수님
- Sort
- 스택
- 정렬
Archives
- Today
- Total
mondegreen
[240329] 알고리즘 리부트 41일차 - 프로그래머스 섬 연결하기 자바 본문
반응형
최소 비용을 구하는 문제이다. 먼저 각 섬의 루트노드를 저장할 배열을 선언한다. 이 때 초기 값은 각자의 인덱스 값이다. 즉, 각자가 루트노드인 것이고 각자의 집합에 속해있는 것이다. 그 다음 건설 비용이 적은 순서대로 먼저 정렬해준 후 순서대로 연결을 해본다. 이 때 연결하기 전 두 섬의 연결되어 있는지는 루트 노드를 찾아서 비교한다. 만약 다르다면 다리 연결에 드는 비용을 정답 변수에 더해주고 유니언 메소드를 통해 한쪽 루트노드를 다른 한 쪽으로 변경해서 합쳐준다. 같을 때 다리를 놓는다면 사이클이 생겨 비효율적이고 최소 비용이 될 수 없다. 이 작업을 반복하며 다리의 갯수가 n-1개 일 때 작업을 완료하면 된다. n개를 연결하는 최소 갯수는 n-1개 이기 때문이다.
import java.util.*;
class Solution {
public static int[] parents;
public static int find(int i){
if(parents[i] == i) return parents[i];
parents[i] = find(parents[i]);
return parents[i];
}
public static void union(int i, int j){
int rootI = find(i);
int rootJ = find(j);
parents[rootJ] = rootI;
}
public int solution(int n, int[][] costs) {
int answer = 0;
int connected = 1;
parents = new int[n];
for(int i = 0; i < n; i++){
parents[i] = i;
}
Arrays.sort(costs, (o1, o2)->
Integer.compare(o1[2], o2[2]));
for(int[] edge : costs){
if(connected == n-1) break;
if(find(edge[0])!=find(edge[1])) {
union(edge[0], edge[1]);
answer+=edge[2];
}
}
return answer;
}
}
반응형
'알고리즘 풀이 및 리뷰 > 프로그래머스' 카테고리의 다른 글
[240401] 알고리즘 리부트 43일차 - 프로그래머스 배달 자바 (0) | 2024.04.01 |
---|---|
[240330] 알고리즘 리부트 42일차 - 프로그래머스 게임 맵 최단거리 자바 (0) | 2024.03.30 |
[240329] 알고리즘 리부트 41일차 - 프로그래머스 영어 끝말잇기 자바 (0) | 2024.03.29 |
[240328] 알고리즘 리부트 40일차 - 프로그래머스 다단계 칫솔 판매 자바 (0) | 2024.03.28 |
[240328] 알고리즘 리부트 40일차 - 프로그래머스 예상 대진표 자바 (0) | 2024.03.28 |