본문 바로가기
백준/C++

백준 1541번 : 잃어버린 괄호 [C++]

by 대니스 2022. 9. 5.

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

 

1541번: 잃어버린 괄호

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

www.acmicpc.net

소스 코드 : 

#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <string>
using namespace std;

int main()
{
	ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL);
	string str;
	cin >> str;

	int sum = 0;
	string num;
	int minus = 0;

	for (int i = 0; i <= str.size(); i++)
	{
		if (str[i] == '-' || str[i] == '+' || i==str.size())
		{
			if (minus)
			{
				sum -= stoi(num);
				num = "";
			}

			else
			{
				sum += stoi(num);
				num = "";
			}
		}
		else
			num += str[i];

		if (str[i] == '-')
			minus = 1;
	}

	cout << sum;
}

마무리 : 이 문제는 괄호에 대한 제한이 없고 최소값을 구해야하기 때문에 때문에 앞에 마이너스가 온다면 괄호를 치면 된다. 글로 하면 상상하기 힘들 것이다. 

 예를 들어 30 - 20 + 50 - 10 + 5 로 최소값을 구하고 싶으면 30 - (20 + 50) - (10 + 5) 로 최소값을 구할 수 있다. 

'백준 > C++' 카테고리의 다른 글

백준 1260번 : DFS와 BFS [C++]  (0) 2022.09.05
백준 1012번 : 유기농 배추 [C++]  (0) 2022.09.05
백준 17626번 : Four Squares [C++]  (0) 2022.09.04
백준 11727 : 2xn 타일링 2 [C++]  (0) 2022.09.04
백준 11726번 : 2xn 타일링 [C++]  (0) 2022.09.04