728x90
반응형

문제

10773번 : 제로

 

10773번: 제로

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

www.acmicpc.net

내가 작성한 코드 (C++ 성공)

#include <iostream>
#include <string.h>
#include <vector>

using namespace std;

int main(){
	int k;
	cin >> k;
	
	int money;
	
	vector<int> wallet;
	
	for(int i=0; i<k; i++){
		cin >> money;
		if(money == 0) {
			if(wallet.size() != 0){
				wallet.pop_back();
			}
		} else {
			wallet.push_back(money);
		}
	}
	
	int sum = 0;
	
	for(int i=0; i<wallet.size(); i++){
		sum += wallet[i];
	}
	
	cout << sum;
	
	return 0;
}

 

정리

vector를 이용해서 문제를 풀어보았다.
vector에는 기본적으로 스택에 대한 함수들을 이용할 수 있기 때문에 스택에 대한 문제를 쉽게 풀 수 있었다.

따라서, 0이란 숫자가 들어오게 되면 pop을 해주면서 빼주고 아닌 경우 push를 해주었다.

728x90
반응형
복사했습니다!