백준 c++/(1-1)백준 c++ 알고리즘 기초

백준 c++ 1874 스택 수열

현구구 2022. 7. 4. 14:02

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

 

1874번: 스택 수열

1부터 n까지에 수에 대해 차례로 [push, push, push, push, pop, pop, push, push, pop, push, push, pop, pop, pop, pop, pop] 연산을 수행하면 수열 [4, 3, 6, 8, 7, 5, 2, 1]을 얻을 수 있다.

www.acmicpc.net

 

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 <string>
#include <vector>
#include <stack>
using namespace std;
 
 
int main() {
    int count;
    cin >> count; //입력받을 숫자 개수
    vector<char> result; //+-결과값을 출력할 vector
    stack<int> istack;
    int x;//입력받을 수열 문자
    int check = 1;//1부터 count까지의 수열을 만드는 것이므로 변수 하나 1로 선언
    while (count--)
    {
        cin >> x;
        while (check <= x)//입력한 수 까지 result에 +를 추가
        {
            istack.push(check);
            result.push_back('+');
            check++;
        }
        if (istack.top() == x)//istack값이 입력한 x 값과 같아지면 pop으로 제거하고 result에 - 추가
        {
            istack.pop();
            result.push_back('-');
        }
    }
    if (istack.size() != 0)//반복문이 끝난 뒤 stack이 비지 않았다면 그 수열은 불가능
    {
        cout << "NO" << endl;
    }
    else
    {
        for (int i = 0; i < result.size(); i++)
        {
            cout << result[i] << '\n';
        }
    }
}
cs

예제 2번의 경우 5 다음 3을 입력했을 때 아무것도 실행되지 않고 바로 4로 넘어가기 때문에 stack에 값이 남아 있게 되고 if문에 걸려 NO가 출력되게 된다.

'백준 c++ > (1-1)백준 c++ 알고리즘 기초' 카테고리의 다른 글

백준 10845 c++ 큐  (0) 2022.07.04
백준 1406 c++ 에디터  (0) 2022.07.04
백준 9012 c++ 괄호  (0) 2022.07.04
백준 9093 c++ 단어 뒤집기  (0) 2022.07.04
백준 10828 c++ 스택  (0) 2022.07.04