앞에 기다리는 시간은 누적되므로, 누적의 값을 줄여야 총량을 줄일 수 있다.
가장 작은 값들을 먼저 선택해서, 총량을 줄이는 방향으로 코드를 작성한다.
해설코드(C++).
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
|
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
int N;
int answer = 0;
int acc = 0;
vector<int> v;
int main() {
cin >> N;
for(int i = 1; i <= N; i++){
int tmp;
cin >> tmp;
v.push_back(tmp);
}
sort(v.begin(), v.end());
for(int i = 0; i < v.size(); i++){
acc += v[i];
answer += acc;
}
cout << answer << endl;
return 0;
}
|
'알고리즘 > 백준' 카테고리의 다른 글
[BOJ 2217] 로프 (0) | 2020.05.30 |
---|---|
[BOJ 2602] 돌다리 건너기 (0) | 2020.05.28 |
[BOJ 1107] 리모컨 (0) | 2020.05.25 |
[BOJ 1182] 부분수열의 합(비트마스크, 재귀함수, C++) (0) | 2020.05.24 |
[BOJ 2688] 줄어들지 않아 (0) | 2020.05.22 |