[STL 컨테이너] stack & queue & priority_queue

Date:     Updated:

카테고리:

태그:

스택 & 큐 & 우선순위 큐

Container Adaptor 👉 다른 컨테이너 클래스들을 상속 받아서 다른 컨테이터 클래스의 객체에 특정한 인터페이스를 제공해준다.

  • 순서 인덱스로 접근하는 Sequence Container, Key로 접근하는 Associative Container과는 다르게 pop() 연산을 통해 삭제시킬 때만 접근할 수 있다.

🔔 스택

#include <stack>

  • 삽입되고 삭제되는 쪽이 한쪽 밖에 없다.
    • 삽입, 삭제가 모두 top에서 이루어짐.
  1. LIFO 방식으로 구현할 때 사용된다.
    • 가장 먼저 삽입된 것이 가장 나중에 삭제되고
    • 가장 나중에 삽입된 것이 가장 먼저 삭제된다.
  2. DFS 깊이 우선 탐색에 사용 된다.
  • vector, deque, list 를 기반으로 사용 가능하다.
    • 내부적으로는 vecotr, deque, list 구조로 구현이 되어 있되 statck과 같이 작동하도록 멤버 함수를 지원한다.
    • 디폴트로 deque 기반으로 작동한다.

함수

  • size() : 스택의 size. 원소 개수 리턴
  • empty() : 스택이 빈 스택인지, 즉 원소 개수가 0 인지에 대한 true or false 리턴
  • top() : 스택에서 가장 나중에 들어간 원소 리턴 삽입 삭제시 무조건 여기서 이루어진다.
  • push(n) : 스택에 원소를 삽입
  • pop() : top()을 삭제한다. 가장 나중에 들어간 원소 삭제

다른 컨테이너들과 다르게 clear()같은 함수가 없기 때문에 일일이 pop() 해주어야 한다.

stack<int> s;
while(!s.empty())
{
    s.pop();
}


🔔 큐

#include <queue>

  • back에서 삽입이 이루어지고 front에서 삭제가 이루어진다.
  1. FIFO 방식으로 구현할 때 사용된다.
    • 가장 먼저 삽입된 것이 가장 먼저 삭제되고
    • 가장 나중에 삽입된 것이 가장 나중에 삭제된다.
  2. BFS 너비 우선 탐색에 사용 된다.

함수

  • 스택의 pop과 다르게
    • front() : 스택에서 가장 먼저 들어간 원소 리턴
    • back() : 스택에서 가장 나중에 들어간 원소 리턴
  • 다른건 다 스택과 동일하다!

  • deque, list 를 기반으로 사용 가능하다.
    • 내부적으로는 deque, list 구조로 구현이 되어 있되 queue과 같이 작동하도록 멤버 함수를 지원한다.
    • 디폴트로 deque 기반으로 작동한다.
  • vector는 불가능하다.
    • 큐 특성상 뒤에서 삽입하고 앞에서 빠져야 하는데 vector는 앞에서 삭제되는 동작은 지원하지 않기 때문.


🔔 우선순위 큐

  • push, pop 연산시 시간 복잡도가 \(logN\) 밖에 걸리지 않는다.
    • Heap 이라서
#include <queue>

priority_queue<int> pq;

#include <queue>

  • ✨우선순위 큐 또한 queue 헤더에서 지원한다.
  • 내림차순 정렬, 즉 Max Heap이 디폴트다.
priority_queue<int> pq;
priority_queue<int, vector<int>, less<int>> pq;
  • 위의 두 선언은 동일한 선언이다.
    • 디폴트로 vector 위에서 돌아가게 된다. 힙을 구현할 수 있는 컨테이너면 다 괜찮다.
    • 디폴트로 Max Heap 즉 내림 차순인 less<int> 최대값부터 pop이 된다.
priority_queue<int, vector<int>, greater<int>> pq;
  • 오름차순인 greater<int> 즉, Min Heap으로 가장 최소값이 먼저 나오도록 한다.
  • 비교 연산자 <을 오름차순(Min Heap)으로 오버로딩 해도 된다.
struct cmp
{
  bool operator()(int a, int b)
  {
    return a > b;  // 오름 차순
  }
}

priority_queue<int, vector<int>, cmp> pq;

  • 위와 같이 정렬 기준을 직접 구현할 수도 있다!
    • 구조체 안에 ()연산자를 오버로딩하여 이 안에 비교 방식을 직접 사용자 정의 할 수 있다.
    • 인수로 넘길땐 cmp() 연산자는 생략하고 구조체 이름 cmp만 넘겨주면 된다.

함수

queue와 다르게 front, back을 사용하지 않고 stack처럼 top을 사용한다.

  • 어차피 큐에 넣더라도 일반 큐처럼 들어간 순서대로 나오는 것이 아닌 우선순위(ex. 값의 크기)에 따라 나오기 때문에 그런 것 같다.
  • push, top, size, empty pop 스택 함수들과 동일


🌜 개인 공부 기록용 블로그입니다. 오류나 틀린 부분이 있을 경우 
언제든지 댓글 혹은 메일로 지적해주시면 감사하겠습니다! 😄

맨 위로 이동하기

댓글남기기