foxpacking

Programming Lessons

Java 언어 Korean

Java 총 정리[84. Stack]

Stack

이전 걸음까지 List, Set, Map에 대해서 공부를 했습니다. 이 3개의 자료구조가 가장 많이 쓰이기 때문에 잘 알아 두셔야 합니다. 이번 걸음에서는 일반적으로 사용은 적지만 그래도 구조를 알고 있으면 도움이 되는 자료구조를 같이 공부를 하도록 하겠습니다.

Stack에 대해서 이번 걸음에서 같이 공부를 해보도록 하겠습니다. Stack은 이전 Method를 공부를 할 때 Method의 call과 back이 Stack구조로 움직인다고 이야기를 했습니다. 이것과 똑같이 동작을 하는 자료구조가 바로 Stack입니다. 이번 걸음을 통해서 Stack에 대해서 자세히 공부를 하도록 하겠습니다.

Stack의 사용 방법과 구조에 대해서 이번 걸음에서 알아보고 또한 Stack을 사용한 예제를 통해서 작동 원리를 이해하고 사용을 할 수 있습니다. 자료구조에서 많이 사용이 되지 않지만 알아두면 좋은 Stack에 대해서 이번 걸음에서 같이 보도록 하겠습니다.

Stack아란?

자료구조Stack메인사진

위에 이미지를 보면 알 수 있듯이 특징이 있습니다. 항아리 구조에 의해서 처음 들어간 자료가 제일 마지막에 나오고 마지막에 들어간 자료가 처음으로 나오는 구조입니다. 이 부분을 꼭 인지를 하고 Stack자료구조를 사용을 하면 됩니다.

Stack 구조

자료구조Stack정리 (1)

위에 사진처럼 구조는 위에 데이터가 빠져야 본인이 나갈 수 있는 구조입니다. 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());
	}
}

Stack자료구조예제결과사진

위 예제 소스와 결과를 보면 알 수 있습니다. push로 “안녕하세요”를 Stack에 넣었지만 빼서 출력을 하면 “요세하녕안”으로 출력이 되게 됩니다. 이 특성을 잘 이해하고 Stack을 사용하면 됩니다.

Dolphin

About Author

Leave a comment

이메일 주소는 공개되지 않습니다. 필수 필드는 *로 표시됩니다

You may also like

Korean Programming 기초

IT 개발자 VS 프로축구선수 비교?

IT 개발자와 프로축구선수의 같은 점과 다른 점? 프로그래밍 공부를 하시면서 개발자로 취업을 하려고 하는데 과연 취업을 할 수 있을까? IT
Korean 클라우드

AWS 로그인 불가능, AWS고객 센터 이메일 문의 결과는?

AWS 고객센터 이메일 문의 솔직후기 AWS를 사용하기 위해 로그인을 하는 경우 이메일로 코드 번호를 보내지만 이메일로 받을 수 없는 상황이거나