Study/자료구조
[C++] STL Stack
Potato potage
2021. 8. 15. 16:56
반응형
스택의 구조
스택의 특징
- 스택의 입출력은 맨 위에서만 일어나고 스택의 중간에서는 데이터를 삭제할 수 없다.
- LIFO (Last-In-Fisrt-Out)의 형태를 가지고 있다.
- A -> B -> C -> D의 순서로 스택에 삽입되었을 경우 삭제 순서는 D -> C -> B -> A가 된다.
- 스택의 가장 위를 top이라고 하며 top 에서 삽입과 삭제가 이루어진다.
- 스택에 요소가 하나도 없을 때 그러한 스택을 공백 스택(empty stack)이라고 한다.
스택의 연산
- push: 스택에 새로운 원소를 삽입
- pop: 스택의 top 원소를 제거하고 반환
- empty: 스택이 비어있는지 검사
- size: 스택의 크기
- swap: 두 스택의 내용을 바꿈
- top: top에 있는 원소를 반환
스택 구현 코드
#include <iostream>
#include <stack>
using namespace std;
int main() {
// 스택 생성
stack<int> s;
// 10, 20, 30 순서로 삽입
s.push(10);
s.push(20);
s.push(30);
cout << "top element: " << s.top() << "\n";
//상단 2개 삭제
s.pop();
s.pop();
cout << "size: " << s.size() << "\n";
cout << "top: " << s.top() << "\n";
cout << "empty: " << (s.empty() ? "YES" : "NO") << "\n";
return 0;
}
반응형