Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
Tags
- CPU 스케줄링
- react
- 일상
- error
- web
- OS
- 협업
- 정렬
- 백준
- 공부
- memory
- C++
- 분할메모리할당
- 코드업
- codeup
- 알고리즘
- 토이프로젝트
- Java
- 프로그래머스
- 타입스크립트
- react-redux
- Operating System
- 파이썬
- Redux
- Spring
- 자료구조
- js to ts
- 스프링
- 기초100제
- 리덕스장바구니
Archives
- Today
- Total
감자튀김 공장🍟
[C++] STL Stack 본문
반응형
스택의 구조
스택의 특징
- 스택의 입출력은 맨 위에서만 일어나고 스택의 중간에서는 데이터를 삭제할 수 없다.
- 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;
}
반응형
'Study > 자료구조' 카테고리의 다른 글
[자료구조] 빅오 표기법(Big-O notation)이란? (0) | 2022.12.27 |
---|---|
[C++] 연결 리스트(Linked List) (0) | 2021.08.20 |
[C++] 이진트리 순회 (0) | 2021.08.18 |
[자료구조] 트리(Tree)란? 🌲🌲 (0) | 2021.08.17 |
[C++] STL Queue (0) | 2021.08.16 |
Comments