[STL 컨테이너] stack & queue & priority_queue
Categories: STL
Tags: Coding Test Cpp STL Data Structure
스택 & 큐 & 우선순위 큐
Container Adaptor
👉 다른 컨테이너 클래스들을 상속 받아서 다른 컨테이터 클래스의 객체에 특정한 인터페이스를 제공해준다.
- 순서 인덱스로 접근하는
Sequence Container
, Key로 접근하는Associative Container
과는 다르게pop()
연산을 통해 삭제시킬 때만 접근할 수 있다.
🔔 스택
#include <stack>
- 삽입되고 삭제되는 쪽이 한쪽 밖에 없다.
- 삽입, 삭제가 모두
top
에서 이루어짐.
- 삽입, 삭제가 모두
LIFO
방식으로 구현할 때 사용된다.- 가장 먼저 삽입된 것이 가장 나중에 삭제되고
- 가장 나중에 삽입된 것이 가장 먼저 삭제된다.
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
에서 삭제가 이루어진다.
FIFO
방식으로 구현할 때 사용된다.- 가장 먼저 삽입된 것이 가장 먼저 삭제되고
- 가장 나중에 삽입된 것이 가장 나중에 삭제된다.
BFS
너비 우선 탐색에 사용 된다.
함수
- 스택의
top
과 다르게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
스택 함수들과 동일
🌜 개인 공부 기록용 블로그입니다. 오류나 틀린 부분이 있을 경우
언제든지 댓글 혹은 메일로 지적해주시면 감사하겠습니다! 😄
Leave a comment