백준 문제 풀이 - 제로 10773번

0

백준문제풀이

목록 보기
76/128

📜 문제 이해하기

나코더 기장 재민이는 동아리 회식을 준비하기 위해서 장부를 관리하는 중이다.
재현이는 재민이를 도와서 돈을 관리하는 중인데, 애석하게도 항상 정신없는 재현이는 돈을 실수로 잘못 부르는 사고를 치기 일쑤였다.
재현이는 잘못된 수를 부를 때마다 0을 외쳐서, 가장 최근에 재민이가 쓴 수를 지우게 시킨다.
재민이는 이렇게 모든 수를 받아 적은 후 그 수의 합을 알고 싶어 한다. 재민이를 도와주자!

💡 문제 재정의

숫자를 부르다가 0을 말하면 가장 최근의 숫자를 지운다.
이 때 부른 숫자의 합을 구하자.

✏️ 계획 수립

스택을 사용하면 구현할 수 있다.
숫자를 부르면 스택에 push를 해주다가 0을 부르면 pop을 해준다. 모든 숫자가 불리면 스택의 수의 합을 출력한다.

💻 계획 수행

import sys

if __name__ == '__main__':
    K = int(sys.stdin.readline().rstrip())
    num_list = []
    for _ in range(K):
        n = int(sys.stdin.readline().rstrip())
        if n != 0:
            num_list.append(n)
        else:
            num_list.pop()
    print(sum(num_list))

🤔 회고

스택을 적절히 사용할 수 있는 문제였다.

profile
https://github.com/joonyeolsim

0개의 댓글