주소 : 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 |