250x250
Notice
Recent Posts
Recent Comments
Link
반응형
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 29 | 30 | 31 |
Tags
- 리소스모니터링
- sql
- deque
- CSS
- spring boot
- alter
- Properties
- List
- date
- html
- Java
- javascript
- NIO
- math
- string
- Calendar
- 힙덤프
- 스프링부트
- scanner
- Union-find
- priority_queue
- union_find
- BFS
- dfs
- GC로그수집
- 큐
- JPA
- map
- 스택
- set
Archives
- Today
- Total
매일 조금씩
백준 11000번 : 강의실 배정 C++ 본문
728x90
반응형
이게 골드라니?! 하는 문제였다.
골드가 다 이러면 얼마나 좋을까..
강의실을 넘겨받을수 있냐없냐 문제다.
- 1~3시 강의실을 2~4강의가 넘겨받을수없으므로 새로운 강의실이 필요하다.
- 3~5시 강의면 1~3시 강의실을 넘겨받을 수 있다.
- pq의 기본 정렬은 내림차순이므로 강의실별 강의 끝나는 시간을 -를 붙여서 pq에 넣는다.
- 만약 어떤 강의가 pq의 top에 있는 가장 빨리 끝나는 강의보다 시작시간이 같거나 늦으면 pop 하고 빠르면 pop하지 않는다.
- 그리고 그 강의의 끝나는 시간을 pq에 넣는다.
#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
#include <queue>
using namespace std;
int n;
const int MAX = 200001;
pair<int, int> arr[MAX];
// 현재 가장 빨리 끝나는 강의의 T가 top에 오도록 담는 queue
priority_queue<int> pq;
int main(void) {
cin >> n;
for (int i = 0; i < n; i++) {
cin >> arr[i].first >> arr[i].second;
}
// 시작시간인 S의 오름차순 정렬
sort(arr, arr + n);
// pq는 기본이 내림차순이므로 오름차순되게 -붙임
pq.push(-arr[0].second);
for (int i = 1; i < n; i++) {
// 현재 가장 빨리 끝나는 강의의 강의실을 쓸수 있는지 판단
if ( -pq.top() <= arr[i].first) {
// 현재 pq의 top인 강의실을 이어받을수 있으므로 top 을 pop
pq.pop();
}
// 강의실을 이어받은 새로운 강의실을 쓰든 pq에 강의 끝나는 시간을 넣는다.
pq.push(-arr[i].second);
}
cout << pq.size() << '\n';
}
728x90
반응형
'알고리즘 > 그리디' 카테고리의 다른 글
백준 12845번 : 모두의 마블 C++ (0) | 2021.06.03 |
---|---|
백준 1946번 : 신입사원 c++ (0) | 2021.06.02 |
[C++] 프로그래머스 : 단속 카메라 (0) | 2021.02.02 |
[C++] 프로그래머스 : 섬 연결하기 (0) | 2021.02.02 |
[C++] 프로그래머스 : 구명보트 (0) | 2021.02.02 |