728x90
2022.02.08
백준 1874 스택수열
# 1874 스택수열
import sys
n = int(input())
stack = []
result = []
s = 0
for i in range(1,n+1):
a = int(sys.stdin.readline())
stack.append(a)
if s - a < 0:
for j in range(abs(s-a)):
result.append('+')
result.append('-')
s = a
else:
if s - a > 1 and (s - 1) not in stack:
result.append('NO')
break
else:
result.append('-')
s = max(a,s)
if 'NO' in result:
print('NO')
else:
for i in result:
print(i)
입력받는 값을 저장하는 stack 리스트와 기호를 저장하는 result 리스트를 생성하고
s의 값을 변경해주면서 그 차이를 통해 result에 기호를 저장해줬다.
성공이라고 돼있어서 아 전에 풀어본 문제구나 하고 봤더니
전혀 기억이 안 나고 마치 새로운 문제를 보는 것 같았다.
어찌어찌 풀기는 했지만 시간 초과가 떠서 pypy3로 채점을 했다.
728x90
'Algorithm' 카테고리의 다른 글
백준 11866 파이썬 (큐) (0) | 2022.02.08 |
---|---|
백준 10814 파이썬 (0) | 2022.02.08 |
백준 2164 파이썬 (0) | 2022.02.07 |
백준 11650 파이썬 (0) | 2022.02.01 |
백준 11050 파이썬 (0) | 2022.01.29 |