[문제]
https://www.acmicpc.net/problem/10773
[풀이]
STL 스택을 이용하는 문제이다.
입력된 정수가 0일 경우에는 가장 최근에 쓴 수를 지우므로, 스택의 empty()를 이용하여, 값이 들어있는 지 확인후, pop() 함수로 삭제하면 된다.
입력된 정수가 0이 아닌 경우에는 원소를 스택에 집어넣기 위해서 push() 함수를 이용하면 된다.
합계 결산은 empty()를 이용하여 값이 있는지 확인하고 pop() 함수를 통해 계산하면 된다.
[코드]
#include <bits/stdc++.h>
using namespace std;
int main() {
ios::sync_with_stdio(0);
cin.tie(0);
int k;
cin >> k;
stack<int> S;
while(k--) {
int n;
cin >> n;
if(n == 0) {
if(!S.empty()) S.pop();
}
else S.push(n);
}
int sum = 0;
while(!S.empty()) {
sum += S.top();
S.pop();
}
cout << sum;
}
'✏️ Algorithm > 알고리즘 풀이' 카테고리의 다른 글
6549번 히스토그램에서 가장 큰 직사각형 - C++ (0) | 2022.07.25 |
---|---|
3015번 오아시스 재결합 - C++ (0) | 2022.07.24 |
10828번 스택 - C++ (0) | 2022.07.16 |
백준 2493번 - 탑 C++ (0) | 2022.04.23 |
백준 10807번 - 개수 세기 C++ (0) | 2022.04.16 |