139p 우선순위큐 커스텀 정렬
190
작성한 질문수 11
- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.
안녕하세요
139p 우선순위큐 커스텀 정렬을 넣을 때 반대로 넣어야 하는 특징이있다고 적혀있습니다. 뭔가 큐의 성질과 관련이 있을 것 같은데 자세한 원리를 알고 싶습니다. 반대로, 우선순위 큐가 아닐 때에는 어떤 원리인지도 궁금합니다. 감사합니다
답변 1
1
안녕하세요 sunny님 ㅎㅎ
우선순위큐 커스텀 정렬을 넣을 때 반대로 넣어야 하는 특징이있다고 적혀있습니다.
>>
C++의 우선순위큐는 최대 힙(max heap)을 기본으로 구현이 되어있으며 가장 큰 요소가 가장 위에 정렬되게 설정이 되어있습니다.
즉, 다음과 같이 했을 때 기본적으로 내림차순 정렬이 되는 것이죠.
priority_queue<int> pq2; // 내림차순
이와 동일하게 < 오퍼레이터에 맞게 x < a.x 로 설정하게 되면 우선순위큐의 가장 맨 위에 가장 큰 요소가 오게 됩니다. 즉, {1, 2, 3}을 넣었을 때 3이 가장 위에 올라오게 되는 것이죠.
보통 vector에서 정렬 할 때 x < a.x 이런 식으로 정렬하게 되면 {1, 2, 3}으로 정렬되고 앞의 요소는 1인데 이와는 반대인 셈이 된다고 생각하면 됩니다.
그렇기 때문에 가장 작은 값을 우선순위 큐 맨 위에서 뽑게 하려면 x > a.x 이런식으로 정의해야 {3, 2, 1} 이런식으로 정렬되기 때문에 반대로 설정해야 합니다.
반대로, 우선순위 큐가 아닐 때에는 어떤 원리인지도 궁금합니다. 감사합니다
>>
이 때는 반대가 아닌 그대로 내림차순이면 -> >, 오름차순이면 < 이런식으로 compare 함수를 정의해서 정렬하면 됩니다.
대표적으로 map이 있습니다. map의 경우 원래는 키가 오름차순 정렬되는데요.
이를 바꾸려면 다음과 같이 하면 됩니다.
#include <bits/stdc++.h>
struct Point {
int y, x;
Point(int y, int x) : y(y), x(x) {}
};
struct customCompare {
bool operator()(const Point& a, const Point& b) const {
return a.x > b.x; // x 값을 기준으로 내림차순 정렬
}
};
int main() {
std::map<Point, int, customCompare> points;
points[Point(1, 2)] = 1;
points[Point(3, 4)] = 2;
points[Point(5, 6)] = 3;
points[Point(7, 8)] = 4;
for (const auto& entry : points) {
std::cout << "(" << entry.first.y << ", " << entry.first.x << ") : " << entry.second << "\n";
}
return 0;
}
또 질문 있으시면 언제든지 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
문제를 고민하는 시간 관련
0
9
2
코딩살구클럽
0
13
1
코딩살구클럽 문의
0
26
2
코딩살구클럽 승인
0
30
2
DP 경우의 수 설명이 이해가 되지 않습니다.
0
32
2
3-F 채점 관련 질문
0
29
1
BFS, DFS 활용이 되는 상황에서의 방향성
0
32
2
코딩살구클럽 승인
0
41
2
코딩살구클럽승인
0
38
3
코딩살구클럽 승인
0
50
2
3-D 관련 질문
0
35
2
코살구 회원가입 문의
0
45
2
코살구 로그인 문제
0
65
2
3-A 문제 풀이 관련 질문
0
56
3
2-O 질문 있습니다
0
38
2
2-T 문제에 관한 질문
0
40
2
코딩 살구 클럽 접속 및 사용방법 문의
0
63
2
안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~
0
64
2
코딩살구클럽 로그인문제
0
78
3
코딩 살구 클럽 로그인 문제
0
84
2
2-J 채점관련 질문
0
66
3
코딩 살구 클럽 Python 지원 가능 여부
0
77
1
살구클럽 아이디 없음 문제
0
76
1
1-O 코딩살구클럽 채점관련 질문
0
60
2





