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 |
Tags
- c++ split
- c++ 조합
- 백준 1049번 기타줄
- 백준 패션왕 신해빈
- C++ 문자열
- 상월곡역 학원
- C++ 9996
- 월곡중 학원
- 백준 10709
- DFS
- 백준 dfs
- 월곡동 학원추천
- 백준 1049번
- 백준 한국이 그리울 땐 서버에 접속하지
- 운영체제
- 백준 9375번 패션왕 신해빈
- 서울사대부고 학원
- 백준 2309번 일곱 난쟁이
- 성북구 학원
- 상월곡동 학원
- OS
- 백준 토마토
- 백준 14246번
- 백준 14246번 K보다 큰 구간
- 월곡역 학원
- 고정 소수점
- C# 병합정렬
- 월곡중학교 학원추천
- 백준 K보다 큰 구간
- 관리형 학원
Archives
- Today
- Total
키베이루's diary
[C++] 백준 11286번 절댓값 힙 본문
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 구조체를 사용하는 것이 편하다.
'알고리즘 > 기타' 카테고리의 다른 글
[C++] 백준 16953번 A -> B (0) | 2022.06.21 |
---|---|
[C++] 백준 1655번 가운데를 말해요 (0) | 2022.06.20 |
[C++] Vector (0) | 2022.06.03 |
[C++] 백준 18870번 좌표압축 (0) | 2022.05.26 |
[C++] 백준 10610번 30 (0) | 2022.05.26 |
Comments