https://www.acmicpc.net/problem/1874
- 스택 의 LIFO 개념을 인지하기 위한? 문제 인 것 같다.
- 스택에는 오름차순으로 들어간다는 점.
- 저는 원하는 결과 수열을 처음에 입력 받아서 큐에 넣어서 하나씩 비교 하였습니다.
- 스택에 넣는 과정에서 큐의 front에 있는 값과 비교를 해서 같지 않으면 스택에 넣고
- 같으면 스택에 넣었다가 뺀다 (한번은 들어갔다 나와야함.)
- 그 후 뺐을때 queue에서도 pop을 해준다.
- 그리고 그 상태에서 stack.top() 값과 queue.front()의 값이 같다면 또 빼주어야 한다 스택 큐 모두에서
- 그래서 for문을 모두 돈 후에 스택이 비어 있으면 수열이 제대로 완성이 될수 있는 것이므로 성공이고
- 그렇지 않다면 스택을 이용해서 원하는 수열을 만들 수가 없는 것이다.
- 그것을 구분하여 출력해주면 된다.( 안되는 경우에 +,-가 아닌 NO만 출력해야 하므로
- 반복문을 돌면서 출력을 해주면 안된다. 그래서 vector<bool>에 push,pop이 일어날 때 마다
- 차례대로 넣어놓고 마지막에 수열이 완성될 수 있는경우 이를 이용하여 +,-를 출력하였다.
- 자료구조는 자신이 필요하다 싶은, 그리고 더 효율적일 것 같은 자료구조를 선택하면 될거 같다.
- 저도 더 컴팩트하고 쉬운 방법은 없는 지 생각해보겠읍니다.
'학부생 공부 > 연습문제(백준)' 카테고리의 다른 글
백준 10989 수정렬하기3 (0) | 2019.11.16 |
---|---|
백준 10773 제로 (0) | 2019.11.16 |
백준 2292 벌집 (0) | 2019.11.13 |
백준 11650 좌표정렬하기 (0) | 2019.11.13 |
백준 2164 카드2 (0) | 2019.11.13 |