https://www.acmicpc.net/problem/25945
문제 풀이
컨테이너의 높이 차이가 1까지 허용되기 때문에 평균 값을 중심으로 컨테이너를 재배치 해야겠다고 생각했다.
값들을 저장한 뒤 내림차순으로 정렬하고 정렬한 숫자에서 합을 n으로 나눈 뒤 나머지 만큼의 컨테이너는 1개가 더 쌓여있을 것이기 때문에 컨테이너를 빼냈다.
평균 컨테이너수보다 적거나 같은 컨테이너들은 앞쪽에서 빼낸 컨테이너들을.채워 넣는 것이기 때문에 break를 시켜줬다.
소스 코드
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
vector<long long> container;
bool compare(long long a, long long b) {
return a > b;
}
int main() {
int n;
long long sum = 0;
cin >> n;
for (int i = 0; i < n; i++) {
long long a;
cin >> a;
container.push_back(a);
sum += container[i];
}
sort(container.begin(), container.end(), compare);
long long avg = sum / n;
long long dis_cnt = sum % n;
long long result = 0;
for (auto x : container) {
if (x <= avg) {
break;
}
if (dis_cnt != 0) {
result += abs(avg + 1 - x);
dis_cnt -= 1;
}
else {
result += abs(avg - x);
}
}
cout << result << '\n';
}
'알고리즘' 카테고리의 다른 글
[백준] 23247번 Ten C++ 문제풀이 (0) | 2023.09.29 |
---|---|
[백준] 25953번 템포럴 그래프 C++ 문제풀이 (0) | 2023.09.23 |
[백준] 25943번 양팔저울 C++ 문제풀이 (0) | 2023.09.23 |
[백준] 26111번 Parentheses Tree C++ 문제풀이 (0) | 2023.09.22 |
[백준] 15486번 퇴사 2 C++ 문제풀이 (0) | 2023.09.15 |