규도자 개발 블로그
[백준/10828/파이썬3(python3)] 스택 본문
문제
정수를 저장하는 스택을 구현한 다음, 입력으로 주어지는 명령을 처리하는 프로그램을 작성하시오.
명령은 총 다섯 가지이다.
- 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이라는 편안한 함수가 있었다는 걸 깨닫고 그것으로 구성하니 아주 쉽게 만들 수 있었다.
'알고리즘 > 풀이' 카테고리의 다른 글
[백준/10871/자바(Java)] X보다 작은 수 (0) | 2018.09.18 |
---|---|
[백준/10869/자바(Java)] 사칙연산 (0) | 2018.09.18 |
[백준/10817/자바(Java)] 세 수 (0) | 2018.09.18 |
[백준/10718/자바(Java)] We love kriii (0) | 2018.09.18 |
[백준/10430/자바(Java)] 나머지 (0) | 2018.09.18 |
Comments