이전 걸음까지 List, Set, Map에 대해서 공부를 했습니다. 이 3개의 자료구조가 가장 많이 쓰이기 때문에 잘 알아 두셔야 합니다. 이번 걸음에서는 일반적으로 사용은 적지만 그래도 구조를 알고 있으면 도움이 되는 자료구조를 같이 공부를 하도록 하겠습니다.
Stack에 대해서 이번 걸음에서 같이 공부를 해보도록 하겠습니다. Stack은 이전 Method를 공부를 할 때 Method의 call과 back이 Stack구조로 움직인다고 이야기를 했습니다. 이것과 똑같이 동작을 하는 자료구조가 바로 Stack입니다. 이번 걸음을 통해서 Stack에 대해서 자세히 공부를 하도록 하겠습니다.
Stack의 사용 방법과 구조에 대해서 이번 걸음에서 알아보고 또한 Stack을 사용한 예제를 통해서 작동 원리를 이해하고 사용을 할 수 있습니다. 자료구조에서 많이 사용이 되지 않지만 알아두면 좋은 Stack에 대해서 이번 걸음에서 같이 보도록 하겠습니다.
Stack아란?
위에 이미지를 보면 알 수 있듯이 특징이 있습니다. 항아리 구조에 의해서 처음 들어간 자료가 제일 마지막에 나오고 마지막에 들어간 자료가 처음으로 나오는 구조입니다. 이 부분을 꼭 인지를 하고 Stack자료구조를 사용을 하면 됩니다.
Stack 구조
위에 사진처럼 구조는 위에 데이터가 빠져야 본인이 나갈 수 있는 구조입니다. push가 데이터를 삽입을 하고 pop이 데이터를 추출을 하게 됩니다. 이렇게 데이터를 관리하고 활용을 하게 됩니다.
Stack 예제 소스
import java.util.Stack;
public class StackTest1 {
public static void main(String[] args) {
// TODO Auto-generated method stub
Stack stack = new Stack();
stack.push("안");
stack.push("녕");
stack.push("하");
stack.push("세");
stack.push("요");
System.out.println(stack.pop());
System.out.println(stack.pop());
System.out.println(stack.pop());
System.out.println(stack.pop());
System.out.println(stack.pop());
}
}
위 예제 소스와 결과를 보면 알 수 있습니다. push로 “안녕하세요”를 Stack에 넣었지만 빼서 출력을 하면 “요세하녕안”으로 출력이 되게 됩니다. 이 특성을 잘 이해하고 Stack을 사용하면 됩니다.