본문 바로가기

알고리즘/백준

[BOJ 11399] ATM

앞에 기다리는 시간은 누적되므로, 누적의 값을 줄여야 총량을 줄일 수 있다.

 

 

 

가장 작은 값들을 먼저 선택해서, 총량을 줄이는 방향으로 코드를 작성한다.

 

 

 

해설코드(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