절대값이 가장 작은 것을 리턴해야 하니까 자동 정렬되는 priority queue를 썼다.
pair<int,int> 는 first를 기준으로 정렬된다. 하지만 first가 똑같으면 second를 기준으로 정렬된다.
따로 정렬함수를 정의하지 않아도 문제 조건에 맞게 정렬됬다.
#include <bits/stdc++.h>
using namespace std;
int n, input;
int main(void) {
ios::sync_with_stdio(0);
cin.tie(0);
priority_queue<pair<int,int>, vector<pair<int,int>>, greater<>> pq;
// <절대값, 원본값>
cin >> n;
while(n--){
cin >> input;
if(input == 0){
if(pq.empty()) cout << 0 << '\n';
else {
cout << pq.top().second << '\n';
pq.pop();
}
}else{
pq.push({abs(input), input});
}
}
return 0;
}
728x90
'알고리즘 > 백준' 카테고리의 다른 글
잃어버린 괄호 백준 1541번 c++ (0) | 2022.02.24 |
---|---|
동전 0 백준 11047번 c++ (0) | 2022.02.24 |
이중 우선순위 큐 백준 7662번 c++ (0) | 2022.02.24 |
Z 백준 1074번 c++ (0) | 2022.02.23 |
경로 찾기 백준 11403번 c++ (0) | 2022.02.23 |