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 | 31 |
Tags
- 함수 parmater
- 1904
- 1668
- Async/Await
- 자류구조
- 1931
- 백준
- 함수 arguments
- 11047
- 함수 선언문
- 렉시컬 스코프
- 배열같은배열아닌너
- 동적계획법
- 1543
- 1568
- 2667
- javascript
- 9461
- 함수 이놈
- event loop
- 1302
- baekjoon
- setTiemOut
- 1236
- 호이스팅
- 비동기처리
- html5
- 11399
- 유사배열
- 탐욕 알고리즘
Archives
- Today
- Total
두치의 개발공부
스택(Stack) 본문
1. 스택 구조
- 가장 나중에 쌓은 데이터를 가장 먼저 빼낼 수 있는 데이터 구조
- 후입 선출 (LIFO : Last-In-First-Out)
- 흔히 컴퓨터에서 가장 많이 쓰는 단축어인 Ctra + Z (실행 취소)의 행위와 똑같다!
2. 용어
- push : 데이터를 스택에 넣기
- pop : 데이터를 스택에서 빼기
3. 추가 설명
- 스택 구조는 프로세스 실행 구조의 가장 기본적인 개념이다.
- 프로그램이 실행되면 프로세스가 됨.
장점
- 구조가 단순하고, 구현이 쉽다.
- 데이터 저장/읽기 속도가 빠르다.
단점
-
4. 구현
Python
stack_list = list();
def push(data):
stack_list.append(data);
def pop():
data = stack_list[-1];
del stack_list[-1];
return data;
Javascript
class Stack {
constructor() {
this.arr = [];
}
push(data) {
this.arr.push(data);
}
pop() {
if (this.arr.length === 0) {
return null;
} else {
const data = this.arr[-1];
this.arr.splice(-1, 1);
return data;
}
}
}
const stack = new Stack();
stack.push(1);
stack.push(2);
stack.pop();
stack.push(3);
console.log(stack);
'자료구조' 카테고리의 다른 글
트리(Tree) (0) | 2022.03.25 |
---|---|
해쉬 테이블(Hash Table) (0) | 2022.03.12 |
링크드 리스트(Linked List) (0) | 2022.02.12 |
큐(Queue) (0) | 2022.01.18 |
배열 (0) | 2022.01.06 |