일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 메뉴리뉴얼
- 프로그래머스
- HashMap
- 영문자 확인
- fragment identifier
- 2017 카카오 코드
- 반복문
- 동적계획법
- 완전 탐색
- 후위 표기법
- 쿼드압축 후 개수세기
- 알고리즘
- 어려웠던 문제
- python
- pandas
- Dynamic Programming
- 문자열
- Java
- Stack
- 에라토스테네스의 체
- dfs
- 보이어무어
- 튜플
- 규칙찾기
- 점프와 순간이동
- 최소공배수
- 순열
- 조합
- 완전탐색
- HashSet
- Today
- Total
csmoon1010의 SW 블로그
Stack(스택) 본문
1. 특성
- 선형구조(자료 간의 관계가 1대 1의 관계를 가짐)
- LIFO(Last In First Out) 구조 (후입선출)
2. 구현 in Java
: java.util에 있는 Stack<E> 클래스를 사용한다.
ex> 정수 스택 : Stack<Integer> stack = new Stack<>();
- empty() : 스택이 비어있는가
- peek() : 스택의 제일 상단에 있는 요소 반환
- pop() : 스택의 제일 상단에 있는 요소 반환 + 제거
- push(E item) : 제일 상단에 요소를 삽입
- search(Obejct o) : 제일 상단의 요소를 1로 하여 객체가 존재하는 위치의 인덱스 반환
3. Stack의 연산
배열, ArrayList 등의 자료구조와 가장 상단의 인덱스를 나타내는 top을 이용해 Stack 자료구조를 구현하고, push와 pop 연산을 나타낼 수 있다.
(1) push
public static void push(int[] stack, int x) {
if(top+1 >= stacksize)
System.out.println("overflow");
else{
stack[++top] = x;
System.out.println("push" + " " + x);
}
}
(2) pop
public static void pop(int[] stack) {
if(top == -1)
System.out.println("underflow");
else {
System.out.println(stack[top--]);
}
}
4. 응용1 : 괄호 검사
(1) 괄호 종류 : 대괄호([]), 중괄호({}), 소괄호(())
(2) 조건
- 왼쪽 괄호 개수와 오른쪽 괄호 개수가 같도록
- 왼쪽 괄호가 오른쪽보다 먼저
- 괄호 사이에는 포함 관계만 존재
(3) 알고리즘
- 왼쪽 괄호 : stack에 삽입
- 오른쪽 괄호 : stack에서 pop하여 괄호의 짝이 맞는지 확인
(stack이 empty()이거나, 짝이 맞지 않는 괄호이거나, 전부 조사했는데 아직 괄호에 남은 요소가 있다면 ERROR)
++ 유사문제 : 프로그래머스 올바른 괄호(level2)
2020/08/03 - [Coding Test/프로그래머스] - [200803] 올바른 괄호 - 연습문제(level2)
4. 응용2 : Function call(함수 호출 관리)
(1) 함수 호출의 원리
- 후입선출 구조
- 호출 : 해당 함수에 필요한 지역변수, 매개변수, 복귀 주소를 Stack에 저장
- 실행 완료 : Stack의 top원소를 pop하여 얻은 복귀주소로 복귀
(2) 프로그램 메모리 공간
- 코드 영역 : 프로그램의 코드(명령문)
- 데이터 영역 : 전역변수, static 변수가 할당 / 프로그램 시작 시 할당되고 종료 시까지 남아있음
- 힙 영역 : 원하는 시점에 메모리 공간에 할당 및 소멸하기 위한 영역
- stack 영역 : 지역변수와 매개변수 할당 / 함수 실행 완료 시 소멸
'Coding Test > 알고리즘' 카테고리의 다른 글
Queue(큐) 자료구조 (0) | 2021.02.03 |
---|---|
백트래킹 기법(Backtracking) (0) | 2021.01.04 |
패턴 매칭 알고리즘(Brute Force, KMP, 보이어 무어) (0) | 2020.11.29 |
Search(검색, 탐색) _ Sequential Search, Binary Search (0) | 2020.11.17 |
DFS(Depth-first Search) / BFS(Breadth-first Search) (0) | 2020.11.04 |