알고리즘/기타
[C++] 백준 11286번 절댓값 힙
키베이루
2022. 6. 9. 09:05
1) 문제설명
https://www.acmicpc.net/problem/11286
11286번: 절댓값 힙
첫째 줄에 연산의 개수 N(1≤N≤100,000)이 주어진다. 다음 N개의 줄에는 연산에 대한 정보를 나타내는 정수 x가 주어진다. 만약 x가 0이 아니라면 배열에 x라는 값을 넣는(추가하는) 연산이고, x가 0
www.acmicpc.net
2) 아이디어
우선순위 큐를 선언하고 비교 연산자를 호출하여 절댓값이 작은것이 우선순위가 되도록 swap을 하였다.
만약 절대값이 같은 경우, 둘 중 값이 작은 것이 우선순위가 되도록 swap 하였다.
3) 코드
#include<iostream>
#include<queue>
#include<deque>
#include<string.h>
#include<math.h>
#include<cmath>
#include<stack>
#include<algorithm>
using namespace std;
struct cmp {
bool operator()(int a, int b) {
if (abs(a) == abs(b)) { // ab의 절대값이 같은 경우
if (a > b) { // a가 양수 b가 음수일 경우
return a > b; // true
}
else return b < a; // b가 양수 a가 음수일 경우 false
}
return abs(a) > abs(b); // 절대값이 작은 순서대로
}
};
int main() {
int n;
priority_queue <int,vector<int>, cmp> pq;
cin >> n;
for (int i = 1; i <= n; i++) {
int x;
cin >> x;
if (x == 0) {
if (pq.empty()) { // 큐가 비었다면
cout << 0 << endl; // 0
}
else {
cout << pq.top() << endl;
pq.pop();
}
}
else {
pq.push(x);
}
}
}
cmp 구조체를 사용하는 것이 편하다.