규도자 개발 블로그

[백준/10828/파이썬3(python3)] 스택 본문

알고리즘/풀이

[백준/10828/파이썬3(python3)] 스택

규도자 (gyudoza) 2018. 9. 18. 23:35

문제

정수를 저장하는 스택을 구현한 다음, 입력으로 주어지는 명령을 처리하는 프로그램을 작성하시오.

명령은 총 다섯 가지이다.

  • push X: 정수 X를 스택에 넣는 연산이다.
  • pop: 스택에서 가장 위에 있는 정수를 빼고, 그 수를 출력한다. 만약 스택에 들어있는 정수가 없는 경우에는 -1을 출력한다.
  • size: 스택에 들어있는 정수의 개수를 출력한다.
  • empty: 스택이 비어있으면 1, 아니면 0을 출력한다.
  • top: 스택의 가장 위에 있는 정수를 출력한다. 만약 스택에 들어있는 정수가 없는 경우에는 -1을 출력한다.

입력

첫째 줄에 주어지는 명령의 수 N (1 ≤ N ≤ 10,000)이 주어진다. 둘째 줄부터 N개의 줄에는 명령이 하나씩 주어진다. 주어지는 정수는 1보다 크거나 같고, 100,000보다 작거나 같다. 문제에 나와있지 않은 명령이 주어지는 경우는 없다.

출력

출력해야하는 명령이 주어질 때마다, 한 줄에 하나씩 출력한다.

입출력 예

입력출력
14
push 1
push 2
top
size
empty
pop
pop
pop
size
empty
pop
push 3
empty
top
2
2
0
2
1
01
0
1
-1
0
3

풀이

input_size = int(input())
stack = []
length_of_stack = len(stack)

for i in range(input_size):
    value = input().split()
    if (value[0] == 'push'):
        stack.append(int(value[1]))
        length_of_stack += 1
    elif (value[0] == 'pop'):
        if length_of_stack == 0:
            print(-1)
        else:
            print(stack[-1])
            stack.pop()
            length_of_stack -= 1
    elif (value[0] == 'size'):
        print(length_of_stack)
    elif (value[0] == 'empty'):
        if length_of_stack == 0:
            print(1)
        else:
            print(0)
    elif value[0] == 'top':
        if length_of_stack == 0:
            print(-1)
        else:
            print(stack[-1])

풀이2

채점기준시간 변경으로 위의 코드는 오답처리되었다. 해서 다시 풀었다.

import sys

input = sys.stdin.readline
command_count = int(input())
stack = []


def command_processor(command_input):
    command = command_input.split()[0]
    if len(command_input.split()) > 1:
        number = command_input.split()[1]

    if command == 'push':
        stack.append(number)
    elif command == 'pop':
        if len(stack):
            print(stack[-1])
            stack.pop()
        else:
            print('-1')
    elif command == 'top':
        if len(stack):
            print(stack[-1])
        else:
            print('-1')
    elif command == 'size':
        print(len(stack))
    elif command == 'empty':
        print(0 if len(stack) else 1)


for i in range(command_count):
    command_processor(input())

설명

Stack형 자료구조를 만드는 문제이다. Stack은 말 그대로 '쌓다'는 의미로써 후입선출, Last In First Out형 자료구조로서 쉽게 생각하자면 책을 쌓아놓을 수 있는 케이스가 있는데 위에서만 접근이 가능하다고 하면 맨 처음에 넣은 책은 모든 책을 빼야지만 뺄 수 있고, 마지막에 넣은 책이 가장 위에 위치해 있으므로 책을 뺀다고 하면 가장 마지막에 넣은 책이 나온다. 그래서 '후입선출(LIFO)'형 자료구조라고 한다.
 사실 맨 처음에 해당 문제를 접했을 땐 push 명령어를 구분하는 걸 re모듈을 이용해서 정규식을 통해 match로 빼야하나 생각을 했었지만 스페이스를 기준으로 배열화 시켜주는 split이라는 편안한 함수가 있었다는 걸 깨닫고 그것으로 구성하니 아주 쉽게 만들 수 있었다.

Comments