-
[STACK] BOJ 1874 번 문제풀이백준 문제풀이/etc 2019. 5. 13. 13:33
문제 분석
문제에 친절하게 스택을 사용하라고 나와있죠? ㅎㅎ
내용은 이렇습니다.
원하는 수를 사용하기 위해서는 반드시
스택에 push, pop 하는 과정을 거쳐야 합니다.
스택에 값은 아래의 그림처럼 채워집니다.
예를 들어, 가장 처음에 5를 사용해야 한다면
1 ~ 5 의 숫자를 push 한 후에 pop 을해서 사용하는 겁니다.
이게 이해가 되셨다면, 만들고자 하는 배열을 저장해야 하는데
이 배열을 큐에 저장하면 간단합니다.
입력 파트를 보면 먼저 입력된 값부터 스택에서
추출하기 때문입니다. 따라서 예시문제를 순서대로
큐에 push 하게 되면 아래 그림처럼 채워집니다.
자, 이제부터 알고리즘을 설계해봅시다.
1. 큐를 선언하여 입력되는 값을 큐에 넣습니다.
2. 우선 큐의 front 값에 대해서 처리해줍니다.
(1) num 이 큐의 front 값이 될 때까지 스택에 Push(+)
(2) 해당 숫자까지 push 했다면 큐와 스택 모두 Pop(-)
3. 처음 값을 찾은 후 반복문 내에서 front 값에 대해 세 가지 경우를 처리합니다.
(1) 스택이 비어있거나 front 값이 스택의 top 보다 큰 경우
(2) front 값이 스택의 top 과 같은 경우
(3) front 값이 스택의 top 보다 작은 경우
4. 가능하면 yes 불가능하면 no 를 출력
코드
#include "bits/stdc++.h" using namespace std; int main() { ios::sync_with_stdio(0); cin.tie(0); stack<int> stc; queue<int> que; string result; int n; cin >> n; for (int i = 0; i < n; i++) { int temp; cin >> temp; que.push(temp); } int num = 1; for (int i = 0; i < que.front(); i++) { stc.push(num); num++; result += '+'; } que.pop(); stc.pop(); result += '-'; bool impossible = false; while (1) { if (que.empty()) break; int cursor = que.front(); if (stc.empty() || stc.top() < cursor) { stc.push(num++); result += '+'; } else if (cursor == stc.top()) { que.pop(); stc.pop(); result += '-'; } else if (stc.top() > que.front()) { impossible = true; break; } } if (impossible) cout << "NO\n"; else for (int i = 0; i < (int)result.size(); i++) cout << result[i] << "\n"; return 0; }
'백준 문제풀이 > etc' 카테고리의 다른 글
[C++] 카카오 코딩테스트 < 길 찾기 게임 > 문제풀이 (0) 2020.02.09 [재귀] BOJ 9095 : 1, 2, 3 더하기 (0) 2019.10.14 [ETC] BOJ 13458 : 시험 감독 (0) 2019.10.01 [Greedy] BOJ 2217 번 : 로프 (0) 2019.06.03 [STACK] BOJ 9012 번 문제풀이 (0) 2019.05.12