본문 바로가기
Computer Science/자료구조

스택(Stack) : LIFO

by Libi 2021. 6. 29.
반응형

스택(Stack)은 후입 선출(LIFO : Last-In First-Out)의 형식으로 입출력이 일어나는 자료구조이다. 가장 최근에 입력되었던 자료의 위치를 Top이라는 변수로 가리키도록 하여 모든 연산에 활용한다.

스택은 삽입(Push), 삭제(Pop) 2가지 기본 연산을 가지고 있다.

JAVA에선 간단하게 라이브러리를 추가하여 별다른 구현 없이 사용할 수 있다.

import java.util.Stack; 
Stack<"자료형"> "스택 이름" = new Stack<>();

 

스택(Stack)은 선형 자료구조로써 배열, 연결 리스트를 이용하여 구현할 수 있다.

배열로 구현하는 방법은 스택의 크기가 고정되는 단점이 있지만 구현이 쉽고, 데이터 접근이 빠르다. 반면, 연결 리스트로 구현하는 방법은 구현이 약간 복잡한 반면, 스택의 크기를 필요에 따라 가변적으로 변경할 수 있다.

다음은 배열로 간단하게 구현한 스택(Stack)이다.

class MyStack<T> {
	private int top;
	private int stackSize;
	private T[] arr;
	
	public MyStack(int stackSize){
		top = -1;
		this.stackSize = stackSize;
		arr = (T[])new Object[stackSize];
	}
	
	public void push(T data) {
		if (is_Full()) {
			throw new ArrayIndexOutOfBoundsException();
		}
		arr[++top] = data;
	}
	
	public T peek() {
		if (is_Empty()) {
			throw new ArrayIndexOutOfBoundsException();
		}
		return arr[top];
	}
	
	public T pop() {
		if (is_Empty()) {
			throw new ArrayIndexOutOfBoundsException();
		}
		T ret = arr[top];
        arr[top--] = null;
		return ret;
	}
	
	public boolean is_Full() {
		if (top + 1 == stackSize) return true;
		return false;
	}
	
	public boolean is_Empty() {
		if (top == -1) return true;
		return false;
	}
	
	public int getSize() {
		return top + 1;
	}
	
	public int getTopElement() {
		return (int) arr[top];
	}
}

구현한 스택(Stack)으로 간단한 예제를 테스트한 결과는 다음과 같다.

MyStack<Integer> st = new MyStack<>(4);
st.push(3);
st.push(5);
st.push(10);
st.push(14);
System.out.println(st.is_Full());
System.out.println(st.getSize());
System.out.println(st.peek());
System.out.println(st.pop());
System.out.println(st.is_Empty());
System.out.println(st.pop());
System.out.println(st.pop());
System.out.println(st.pop());
System.out.println(st.is_Empty());

반응형

'Computer Science > 자료구조' 카테고리의 다른 글

그래프(Graph)  (0) 2021.06.30
우선순위 큐(Priority Queue)  (0) 2021.06.30
트리(Tree)  (0) 2021.06.30
덱(Deque)  (0) 2021.06.29
큐(Queue) : FIFO  (0) 2021.06.29

댓글