article thumbnail image
Published 2023. 1. 12. 18:41

문제 설명

https://www.acmicpc.net/problem/10773

 

10773번: 제로

첫 번째 줄에 정수 K가 주어진다. (1 ≤ K ≤ 100,000) 이후 K개의 줄에 정수가 1개씩 주어진다. 정수는 0에서 1,000,000 사이의 값을 가지며, 정수가 "0" 일 경우에는 가장 최근에 쓴 수를 지우고, 아닐 경

www.acmicpc.net

문제 풀이법

일단 k개의 수를 입력 받은 후 stack을 선언하여 입력 받은 수가 0이 아닐때는 stack에 push 해준다

문제에서 입력받은 수가 0일 경우 지울 수가 있음을 보장할 수 있다고 하였으므로, 입력 받은 수가 0이면 pop을 해준다 

 

소스 코드

#include <iostream>
#include <stack>

using namespace std;

int main()
{
    int n;
    
    cin >> n;
    
    stack<int> s;
    for (int i = 0; i < n; i++)
    {
        int tmp;
        cin >> tmp;
        
        if (tmp != 0)
            s.push(tmp);
        else
            s.pop();
    }
    
    int ans = 0;
    while (!s.empty())
    {
        ans += s.top();
        s.pop();
    }
    printf("%d\n", ans);
}

'Algorithm Study' 카테고리의 다른 글

[백준] 2493 탑  (0) 2023.01.12
[백준] 1874 스택 수열  (0) 2023.01.12
[백준] 10828 스택  (0) 2023.01.12
[프로그래머스] 1단계 - 크기가 작은 부분 문자열  (0) 2023.01.11
[프로그래머스] 1단계 - 실패율  (0) 2023.01.11
복사했습니다!