Programmers_Heap03 - 이중우선순위 큐
Programmers_Heap03 - 이중우선순위 큐
프로그래머스 - 이중우선순위 큐 문제 입니다.
1. 문제
https://programmers.co.kr/learn/courses/30/parts/12077
2. 분류 및 난이도
Programmers 문제입니다.
level 3의 문제입니다.
3. 생각한 것들(문제 접근 방법)
- 어떤 자료구조에 앞 뒤로 숫자를 넣고 빼는 것은 deque에 어울리지 않을까해서 deque를 사용했습니다.
- 불필요한 반복을 줄이기 위해 정렬 여부를 판단하는 bool 타입 변수 check를 두었습니다.
- Insert만 들어올 경우를 대비해 마지막에 한 번 더 정렬을 해줬습니다.
4. 접근 방법을 적용한 코드
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
#include <string>
#include <vector>
#include<deque>
#include<iostream>
#include<algorithm>
using namespace std;
bool pred(int& a, int& b)
{
return a < b;
}
vector<int> solution(vector<string> operations) {
vector<int> answer;
deque<int> dq;
string str;
//정렬 판단 여부
bool check = false;
for (size_t i = 0; i < operations.size(); ++i)
{
str = operations[i];
// I,D 인지 확인
char query = str[0];
//숫자가 앞에 오도록 잘라줌
str = str.substr(2);
// 뒤의 숫자 문자열을 숫자 자료형으로 치환
int insert = stoi(str);
if (query == 'I')//insert
{
dq.push_back(insert);
//정렬해라 라는 의미
check = true;
}
else
{
if (insert == 1)
{
//정렬을 해야하면
if (check)
{
sort(dq.begin(), dq.end(),pred);
check = false;
}
if(!dq.empty())
dq.pop_back();
}
else
{
if (check)
{
sort(dq.begin(), dq.end(),pred);
check = false;
}
if (!dq.empty())
dq.pop_front();
}
}
}
if (dq.empty())
{
answer.push_back(0);
answer.push_back(0);
}
else
{
//Insert만 들어올 경우 정렬 다시 해줘야하므로
sort(dq.begin(), dq.end(), pred);
answer.push_back(dq.back());
answer.push_back(dq.front());
}
return answer;
}
5. 결과
This post is licensed under CC BY 4.0 by the author.