한쪽 끝에서만 자료를 넣고 뺄 수 있는 자료구조
마지막으로 넣은 것이 가장 먼저 나오기 때문에 Last In First Out(LIFO) 라고도 한다.
먼저 각각의 함수를 구현합니다.
사용자 입력은 string 값으로 받는 것이기 때문에 in 을 사용해서 명령어를 구분해주고, 사용자 입력에 맞는 함수를 실행합니다.
import sys
# 1. push X
def push(stack, x):
stack.append(x)
return stack
# 2. pop
def pop(stack):
if(stack):
num = stack.pop()
else:
num = -1
print(num)
return stack
# 3. size
def size(stack):
print(len(stack))
# 4. empty
def empty(stack):
if(stack):
print(0)
else:
print(1)
# 5. top
def top(stack):
if(stack):
print(stack[-1])
else :
print(-1)
stack = []
sys.stdin.readline()
for line in sys.stdin:
if("push" in line):
x = line.split()[-1]
push(stack, int(x))
elif ("pop" in line):
pop(stack)
elif ("size" in line):
size(stack)
elif ("empty" in line):
empty(stack)
elif ("top" in line):
top(stack)
else:
print("error")
백준 10845 - 큐 (자료구조, 파이썬) (1) | 2020.12.27 |
---|---|
백준 9012 - 괄호 (파이썬) (0) | 2020.12.27 |
백준 1924 - 2007년 (파이썬) (0) | 2020.12.27 |
백준 10953 - A + B - 6 (파이썬) (0) | 2020.12.26 |
백준 2558 - A + B - 2 (파이썬) (0) | 2020.12.26 |