*코테 준비용으로 자료구조 정리 시작, 자바 위주로 정리
스택(Stack): 스택은 쌓아놓은 더미라는 의미로 스택은 데이터를 쌓는 LIFO(Last In First Out)의 특성을 갖는 선형 자료구조
-top 부분으로만 데이터 입출력이 되기 때문에 가장 먼저 들어온 데이터가 가장 마지막으로 나가고, 가장 마지막에 들어온 데이터가 가장 먼저 나가는 구조
-웹 브라우저의 방문 기록이나 재귀 함수 호출 등에서 사용
Top : 스택의 가장 위에 있는 데이터
Bottom: 스택의 가장 아래 있는 데이터
스택이 꽉 차면(capacity == size) 포화상태라고 하며, Full Stack이라고 한다.
스택 연산
- pop() : 스택에서 top에 있는 항목을 제거
- push(element) : element 하나를 스택의 top에 추가
- peek() : 스택의 top에 있는 항목을 반환(삭제 x)
- isEmpty() : 스택이 비어 있는지 확인
Java Stack Class
직접 구현해서 사용해도 되지만, java.util에 Stack 클래스가 있음
Stack<T> stack = new Stack<>();와 같은 방식으로 선언, 데이터 타입(T)은 클래스와 Wrapper Class
import java.util.Stack; //import
Stack<Integer> stack = new Stack<>();
stack.push(10);
stack.push(11);
stack.peek(); //11
stack.pop(); //11
stack.isEmpty(); //false
stack.pop(); //10
stack.isEmpty(); //true