Programmers_Greedy03 - 섬 연결하기
프로그래머스 -섬 연결하기 문제 입니다.
1. 문제
https://programmers.co.kr/learn/courses/30/parts/12077
2. 분류 및 난이도
Programmers 문제입니다.
level 3의 문제입니다.
3. 생각한 것들(문제 접근 방법)
- 크루스칼 알고리즘 문제입니다.
4. 접근 방법을 적용한 코드
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
#include <string>
#include <vector>
#include<iostream>
#include<queue>
#include<algorithm>
using namespace std;
//부모 노드를 가져옴
int getParent(int set[], int x)
{
if (set[x] == x)return x;
return set[x] = getParent(set, set[x]);
}
//부모 노드를 병합
void unionParent(int set[], int a, int b)
{
a = getParent(set, a);
b = getParent(set, b);
if (a < b)set[b] = a;
else set[a] = b;
}
int find(int set[], int a, int b)
{
a = getParent(set, a);
b = getParent(set, b);
if (a == b)return 1;
else
return 0;
}
class Edge {
public:
int node[2];
int distance;
Edge(int a, int b, int distance)
{
this->node[0] = a;
this->node[1] = b;
this->distance = distance;
}
bool operator<(Edge& edge)
{
return this->distance < edge.distance;
}
};
int solution(int n, vector<vector<int>> costs) {
int answer = 0;
vector<Edge> v;
for (size_t i = 0; i < costs.size(); ++i)
{
v.push_back(Edge(costs[i][0], costs[i][1], costs[i][2]));
}
sort(v.begin(), v.end());
int* set = new int[n+1];
for (int i = 0; i < n; ++i)
{
set[i] = i;
}
for (int i = 0; i < v.size(); ++i)
{
if (!find(set, v[i].node[0], v[i].node[1]))
{
answer += v[i].distance;
unionParent(set, v[i].node[0], v[i].node[1]);
}
}
return answer;
}
5. 결과
This post is licensed under CC BY 4.0 by the author.