728x90
https://www.acmicpc.net/problem/2979
#include <iostream>
#include <vector>
#include <queue>
#include <string>
#include <algorithm>
using namespace std;
int main() {
int fee[3];
for (int i = 0; i < 3; i++) {
cin >> fee[i];
}
int arriveTime[3];
int leaveTime[3];
vector<pair<int, int>> time;
for (int i = 0; i < 3; i++) {
cin >> arriveTime[i];
cin >> leaveTime[i];
time.push_back(make_pair(arriveTime[i], 1));
time.push_back(make_pair(leaveTime[i], -1));
}
sort(time.begin(), time.end());
int count = 1;
int totalFee = 0;
int previousTime = time[0].first;
for (int i = 1; i < 6; i++) {
int feePerHour = fee[count - 1];
int now = time[i].first;
totalFee += ((now - previousTime) * feePerHour * count);
count += time[i].second;
previousTime = time[i].first;
}
cout << totalFee;
return 0;
}
어제도 그래놓고는.. 오늘도 다짐한다. 문제를 똑바로 읽자.
트럭 1대면 A원, 2대면 B원, 3대면 C원인 줄 알았는데 한 대당 A원, B원, C원이었다.
728x90
'알고리즘 문제' 카테고리의 다른 글
[백준] 1991번 트리 순회 (0) | 2020.02.12 |
---|---|
[백준] 6376번 e 계산 (0) | 2020.02.11 |
[백준] 5532번 방학 숙제 (0) | 2020.02.11 |
[백준] 2661번 좋은 수열 (시간초과로 미해결) (0) | 2020.02.11 |
[백준] 1759번 암호 만들기 (0) | 2020.02.11 |