본문 바로가기
코테/Greedy

[C/C++] 백준 1541, Greedy

by 상똥 2023. 2. 9.

문제

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

 

1541번: 잃어버린 괄호

첫째 줄에 식이 주어진다. 식은 ‘0’~‘9’, ‘+’, 그리고 ‘-’만으로 이루어져 있고, 가장 처음과 마지막 문자는 숫자이다. 그리고 연속해서 두 개 이상의 연산자가 나타나지 않고, 5자리보다

www.acmicpc.net

 

코드

#include <vector>
#include <algorithm>
#include <string>
#include <iostream>

using namespace std;

int main() {
	vector<int> cal;
	vector<int> num;
	string input;
	string temp;

	cin >> input;
	cal.push_back(0);
	for (int i = 0; i < input.size() + 1; i++) {
		if (i == input.size()) {
			num.push_back(stoi(temp));
			temp = '0';
			break;
		}
		if ((input[i] == '-') || (input[i] == '+')) {
			num.push_back(stoi(temp));
			temp = '0';
			if (input[i] == '-')
				cal.push_back(-1);
			else
				cal.push_back(1);
		}
		else
			temp += input[i];
	}

	int result = num[0];
	for (int i = 1; i < cal.size(); i++) {
		if (cal[i] == -1) {
			result -= num[i];
			if (i != cal.size() - 1)
				if (cal[i + 1] == 1)
					cal[i + 1] *= -1;
		}
		else
			result += num[i];
	}
	cout << result;
}

풀이