본문 바로가기
백준(C++)/자료구조1

[BOJ/C++]10799_쇠막대기

by 코잼민 2024. 7. 13.

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

 

##문제 풀기 전 내가 알고 있었어야 할 개념:

1_ "Stack_SIZE" 와 "막대기 개수"와 관련이 있다는 것을 눈치 채기 어려웠다.

=> 앞으로, Stack_SIZE를 상황에 매칭하는 습관을 가져보자 

2_ Pop()할 때, 연산 값이 변할텐데, 그 때 많이 상황을 분석하면서, Case분류하는 것이 매우매우 시발 어려웠다.

   2_1) 레이저의 Pop() => Stack_size()를 막대기 개수에 합한다. 

   2_2) 레이저가 아닐때, Pop() => 막대기 개수++

   2_3) 최종 막대기의 끝지점 Pop() (Stack이 Empty()일 때)

## 예제입력 1 분석 노트 정리

##코드

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
#include <iostream>
#include <stack>
#include <string>
 
using namespace std;
 
int main() {
 
    string input;
    stack <char> S;
    int sum = 0;
    int sum_2 = 0;
    char tmp_c=0;
 
    cin >> input;
 
    for (int i = 0; i < input.length(); i++) {
        if (i != 0) {
            tmp_c = input[i - 1];
        }
        char c = input[i];
 
        if (c == '(') {
            S.push(c);
        }
        else {
            S.pop();
 
            if (tmp_c == '(') {//레이저 Pop() 상황
                sum += S.size();
            }
            else {//그 외 Pop() 상황
                sum++;
            }
        }
    }
 
    cout << sum<<'\n';
 
    return 0;
}
cs