10773 - 제로 (https://www.acmicpc.net/problem/10773)
알고리즘 분류 : 구현, 자료 구조, 문자열, 스택
시간 제한 : 1 초
스택으로 값을 계속 채우다가, 0이 들어오면 pop()으로 가장 최근 값을 날리고, 숫자가 모두 입력된 후 총합을 출력하면 되는 문제이다.
나는 처음 문제를 구현할 때 스택 대신 가장 최근 값만을 기록하는 방식을 사용했다.
#include <cstdio>
using namespace std;
int main()
{
int late;
int n;
int input;
long long int total;
scanf("%d", &n);
for(int i=0;i<n;i++)
{
scanf("%d", &input);
if (input == 0)
{
total -= late;
} else {
late = input;
total += late;
}
}
printf("%lld", total);
}
total이 2의 23승보다 작은 정수이기 때문에 long long int로 선언했다.
이 방법의 문제점은 0이 연속으로 두번 들어올 때 두번째로 늦게 들어온 값을 알 수 없다는 것이다.
#include <cstdio>
#include <stack>
using namespace std;
int main()
{
stack<int> st;
int n;
int input;
long long int total = 0;
scanf("%d", &n);
for(int i=0;i<n;i++)
{
scanf("%d", &input);
if (input == 0)
{
st.pop();
} else {
st.push(input);
}
}
while(!st.empty())
{
total += st.top();
st.pop();
}
printf("%lld", total);
}
그래서 스택을 통해 값을 모두 저장하고, 입력이 끝나면 스택 안에 들어있는 값들을 총합에 더하여 출력하는 방식으로 바꿨다.
'옛날 글들 > PS - C++' 카테고리의 다른 글
1620 - 나는야 포켓몬 마스터 이다솜 #자료 구조 #해시를 사용한 집합과 맵 (0) | 2021.07.20 |
---|---|
[MAC M1] VSCODE C++ 컴파일 설정하기 (3) | 2021.02.03 |