[백준] 13164번 행복 유치원
🔔 문제
행복 유치원 원장인 태양이는 어느 날 N명의 원생들을 키 순서대로 일렬로 줄 세우고, 총 K개의 조로 나누려고 한다. 각 조에는 원생이 적어도 한 명 있어야 하며, 같은 조에 속한 원생들은 서로 인접해 있어야 한다. 조별로 인원수가 같을 필요는 없다.
이렇게 나뉘어진 조들은 각자 단체 티셔츠를 맞추려고 한다. 조마다 티셔츠를 맞추는 비용은 조에서 가장 키가 큰 원생과 가장 키가 작은 원생의 키 차이만큼 든다. 최대한 비용을 아끼고 싶어 하는 태양이는 K개의 조에 대해 티셔츠 만드는 비용의 합을 최소로 하고 싶어한다. 태양이를 도와 최소의 비용을 구하자.
입력
- 입력의 첫 줄에는 유치원에 있는 원생의 수를 나타내는 자연수 N(1 ≤ N ≤ 300,000)과 나누려고 하는 조의 개수를 나타내는 자연수 K(1 ≤ K ≤ N)가 공백으로 구분되어 주어진다. 다음 줄에는 원생들의 키를 나타내는 N개의 자연수가 공백으로 구분되어 줄 서 있는 순서대로 주어진다. 태양이는 원생들을 키 순서대로 줄 세웠으므로, 왼쪽에 있는 원생이 오른쪽에 있는 원생보다 크지 않다. 원생의 키는 109를 넘지 않는 자연수이다.
출력
- 티셔츠 만드는 비용이 최소가 되도록 K개의 조로 나누었을 때, 티셔츠 만드는 비용을 출력한다.
🎯 풀이방법
원생들의 키를 오름차순으로 입력 받았다. n명의 원생을 k개의 조로 나눈다는 것은 즉, n-k개의 키 차이를 무시할 수 있다는 것이다. 키의 차이값을 diff 배열에 저장하였고 오름차순으로 정렬한 뒤에 앞에서부터 n-k개의 차이값들을 더해주면 정답이 된다.
💻 python code
n, k = map(int, input().split()) # 원생 수, 조의 개수
height = list(map(int, input().split()))
diff = []
for i in range(n-1):
diff.append(height[i+1]-height[i]) # 원생 들의 키 차이
diff.sort()
cost = 0
for i in range(n-k):
cost += diff[i]
print(cost)
Author And Source
이 문제에 관하여([백준] 13164번 행복 유치원), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://velog.io/@subinmun1997/백준-13164번-행복-유치원저자 귀속: 원작자 정보가 원작자 URL에 포함되어 있으며 저작권은 원작자 소유입니다.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)