본문 바로가기
  • 개발 삽질 블로그
프로그래밍/자료구조

스택(Stack)

by 갹둥 2023. 12. 15.

*코테 준비용으로 자료구조 정리 시작, 자바 위주로 정리

 

스택(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
 

'프로그래밍 > 자료구조' 카테고리의 다른 글

큐(Queue)  (1) 2023.12.22