less than 1 minute read

  • 오늘은 손대는 문제마다 안풀려서 한문제밖에 풀지 못했다.

1. 제로

  • 나코더 기장 재민이는 동아리 회식을 준비하기 위해서 장부를 관리하는 중이다.

  • 재현이는 재민이를 도와서 돈을 관리하는 중인데, 애석하게도 항상 정신없는 재현이는 돈을 실수로 잘못 부르는 사고를 치기 일쑤였다.

  • 재현이는 잘못된 수를 부를 때마다 0을 외쳐서, 가장 최근에 재민이가 쓴 수를 지우게 시킨다.

  • 재민이는 이렇게 모든 수를 받아 적은 후 그 수의 합을 알고 싶어 한다. 재민이를 도와주자!

입력

  • 첫 번째 줄에 정수 K가 주어진다. (1 ≤ K ≤ 100,000)

  • 이후 K개의 줄에 정수가 1개씩 주어진다. 정수는 0에서 1,000,000 사이의 값을 가지며, 정수가 “0” 일 경우에는 가장 최근에 쓴 수를 지우고, 아닐 경우 해당 수를 쓴다.

  • 정수가 “0”일 경우에 지울 수 있는 수가 있음을 보장할 수 있다.

출력

  • 재민이가 최종적으로 적어 낸 수의 합을 출력한다.
  • 최종적으로 적어낸 수의 합은 $2^{31}-1$보다 작거나 같은 정수이다.

풀이

import sys

K = int(sys.stdin.readline())
arr = []

for _ in range(0, K):
    n = int(sys.stdin.readline())
    if n == 0:
        arr.pop()
    else:
        arr.append(n)

print(sum(arr))

채점 결과

  • 정답

리뷰

  • 0이 나오면 스택을 pop, 그 이외에는 스택에 push한후 stack의 모든 내용물을 더하는 문제다.