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 |