13164번 : 행복한 유치원
문제)
행복 유치원 원장인 태양이는 어느 날 N명의 원생들을 키 순서대로 일렬로 줄 세우고, 총 K개의 조로 나누려고 한다. 각 조에는 원생이 적어도 한 명 있어야 하며, 같은 조에 속한 원생들은 서로 인접해 있어야 한다. 조별로 인원수가 같을 필요는 없다.
이렇게 나뉘어진 조들은 각자 단체 티셔츠를 맞추려고 한다. 조마다 티셔츠를 맞추는 비용은 조에서 가장 키가 큰 원생과 가장 키가 작은 원생의 키 차이만큼 든다. 최대한 비용을 아끼고 싶어 하는 태양이는 K개의 조에 대해 티셔츠 만드는 비용의 합을 최소로 하고 싶어한다. 태양이를 도와 최소의 비용을 구하자.
입력 :
입력의 첫 줄에는 유치원에 있는 원생의 수를 나타내는 자연수 N(1 ≤ N ≤ 300,000)과 나누려고 하는 조의 개수를 나타내는 자연수 K(1 ≤ K ≤ N)가 공백으로 구분되어 주어진다. 다음 줄에는 원생들의 키를 나타내는 N개의 자연수가 공백으로 구분되어 줄 서 있는 순서대로 주어진다. 태양이는 원생들을 키 순서대로 줄 세웠으므로, 왼쪽에 있는 원생이 오른쪽에 있는 원생보다 크지 않다. 원생의 키는 10^9를 넘지 않는 자연수이다.
출력 :
티셔츠 만드는 비용이 최소가 되도록 K개의 조로 나누었을 때, 티셔츠 만드는 비용을 출력한다.
풀이)
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
|
// 13164. 행복 유치원
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
int n, k;
vector<int> vec;
int main()
{
ios_base::sync_with_stdio(false);
cin.tie(0);
cin >> n >> k;
int a, b;
cin >> a;
// 각 유치원생의 키 차이값을 배열로 만든다.
for (int i = 0; i < n - 1; i++)
{
cin >> b;
vec.push_back(b - a);
a = b;
}
sort(vec.begin(), vec.end());
/*
5 3
2
1 3 5 6 10
2 2 1 4
정렬 후
1 2 2 4
*/
int ans = 0;
for (int i = 0; i < vec.size() - (k - 1); i++)
{
ans += vec[i];
}
cout << ans;
return 0;
}
|
cs |
출처 : https://www.acmicpc.net/problem/13164
13164번: 행복 유치원
행복 유치원 원장인 태양이는 어느 날 N명의 원생들을 키 순서대로 일렬로 줄 세우고, 총 K개의 조로 나누려고 한다. 각 조에는 원생이 적어도 한 명 있어야 하며, 같은 조에 속한 원생들은 서로
www.acmicpc.net
'Develop > 백준 (Cpp)' 카테고리의 다른 글
[백준] 2194번 : 유닛 이동시키기 (C++) (0) | 2023.10.04 |
---|---|
[백준] 12865번 : 평범한 배낭 (C++) (0) | 2023.10.03 |
[백준] 9655번 : 돌 게임 (C++) (0) | 2023.10.03 |
[백준] 17404번 : RGB거리 2 (C++) (0) | 2023.10.02 |
[백준] 1244번 : 스위치 켜고 끄기 (C++) (0) | 2023.10.02 |