반응형
문제
https://www.acmicpc.net/problem/7983
풀이
그리디 문제..
처음엔 배열을 만들어서 배열에 해당 날짜에 체크를 하고..
체크가 안된부분이 나온 처음 인덱스로 답을 정하려했는데 인덱스 오류가 났다ㅠㅠ
그래서 풀이를..보고... 풀어보았다. time>=end 마감일이 시작일보다 이른경우다.
쉽게 말해 이미 마감일에 다른일을 했으면 지금까지 저장된 time에서 걸리는 시간을 빼준 값을 time에 갱신해야한다..
쉽지않네
코드
#include <bits/stdc++.h>
using namespace std;
int n;
vector<pair<int, int>> v;
int main(void) {
ios_base::sync_with_stdio(0);
cin.tie(0);
cin >> n;
int m = n;
while (m--) {
int d, t;
cin >> d >> t;
v.push_back({ t,d });
}
sort(v.begin(), v.end());
reverse(v.begin(), v.end());
int time = v[0].first;
for (int i = 0; i < n; i++) {
int end = v[i].first;//13,10,8
int st = v[i].second;//1,3,2
if (time >= end) {
//마감일이 시작일보다 이른 경우 13,13
time = end - st;//12로 갱신. 다음은 10이랑 비교
}
else {
time = time - st;//time이 7인데 end가 8이면
//time에 7-2 저장
}
}
cout << time;
}
반응형
'알고리즘' 카테고리의 다른 글
[백준/17298][C++] 오큰수 (1) | 2023.10.21 |
---|---|
[백준/2812][C++] 크게 만들기 (0) | 2023.10.21 |
[백준/9694][C++] 무엇을 아느냐가 아니라 누구를 아느냐가 문제다 (0) | 2023.10.20 |
[백준/17835][C++] 면접보는 승범이네 (2) | 2023.09.28 |
[백준/21608][Python] 상어 초등학교 (0) | 2023.09.23 |