Algorithm

(BOJ) 10799

snwo 2022. 2. 2. 19:27
#include <bits/stdc++.h>
using namespace std;

stack<char> S;
int main(void)
{
    ios::sync_with_stdio(0);
    cin.tie(0);
    string input;
    int sum = 0;
    cin >> input;
    for (int i=0;i<input.size();i++)
    {
        if (input[i] == '(')
            S.push('(');
        else
        { // c == ')'
            if (input[i-1] == '(')
            { // laser
                S.pop();
                sum += S.size();
            }
            else
            { // end of the iron rod
                S.pop();
                sum++;
            }
        }
    }
    cout << sum;
}

열린괄호 : 쇠막대, 스택에 push 하여 겹쳐있는 막대의 개수를 구할 떄 사용

닫힌괄호 : 쇠막대의 끝을 나타낸다.

레이저로 잘려서 남은 쇠막대, 혹은 잘리지 않고 남은 쇠막대를 의미한다.

스택에서 하나 pop 한 뒤, 쇠막대 카운트 +1

열린괄호&닫힌괄호가 연속해 있는 경우 : 레이저이다. 레이저 기준으로 잘린 왼쪽의 막대만큼 카운트 (stack size)