inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트

[특강] 내가 IT대기업에 합격한 방법

139p 우선순위큐 커스텀 정렬

190

sunnyside0102

작성한 질문수 11

0

- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.

 

 

안녕하세요

139p 우선순위큐 커스텀 정렬을 넣을 때 반대로 넣어야 하는 특징이있다고 적혀있습니다. 뭔가 큐의 성질과 관련이 있을 것 같은데 자세한 원리를 알고 싶습니다. 반대로, 우선순위 큐가 아닐 때에는 어떤 원리인지도 궁금합니다. 감사합니다

c++ 코딩-테스트

답변 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