Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 파이썬
- 야근지수
- 해커랭크
- python
- Interview Preparation Kit
- BFS: Shortest Reach in a Graph
- 격파르타 장점
- 코딩테스트
- 피보나치 함수
- Special String Again
- Recursion: Davis' Staircase
- Max Array Sum
- DFS: Connected Cell in a Grid
- Find the nearest clone
- Common Child
- 구슬탈출2
- [sqld]자격증합격
- programmers
- 격파르타 합격후기
- 격파르타 후기
- 알고리즘
- 백준
- Algorithm
- Reverse Shuffle Merge
- 프로그래머스
- candies
- Roads and Libraries
- hackerrank
- 매칭점수
- 머신러닝
Archives
- Today
- Total
Archive
[BOJ] 스택수열 본문
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 ~ N까지 전체 iteration수행
-
정답을 target에 리스트형태로 저장.
-
stack, target을 비교하면서 push, pop연산 수행
-
n과 target값과 같으면 stack의 값을 역순으로 다시 확인하면서 push, pop연산 수행.
N = int(input())
target = [int(input()) for i in range(N)]
target_pos = 0
ans = []
stack = []
switch = 0
# 1부터 n까지 전체 iteration
for n in range(1, N+1):
if n < target[target_pos]:
stack.append(n)
ans.append('+')
elif n == target[target_pos]:
ans.append('+')
ans.append('-')
target_pos += 1
# 뒤로 돌면서 확인
stack_back_idx = len(stack)-1
while stack_back_idx >= 0:
# 봤는데 target과 같음 -> pop
if stack[stack_back_idx] == target[target_pos]:
stack_back_idx -= 1
target_pos += 1
stack.pop()
ans.append('-')
elif stack[stack_back_idx] < target[target_pos]:
break
else:
switch = 1
break
if switch == 1:
print('NO')
break
if switch != 1:
print('\n'.join([i for i in ans]))
'공부 > Algorithm' 카테고리의 다른 글
[BOJ] 1697 숨바꼭질 (0) | 2021.01.31 |
---|---|
[BOJ] 1406 에디터 (0) | 2021.01.31 |
[BOJ] 9012 괄호 (0) | 2021.01.24 |
[BOJ] 10828. 스택 (0) | 2021.01.16 |
[BOJ] 9093. 단어 뒤집기 (0) | 2021.01.16 |
Comments