❓ 문제
시간 제한 | 메모리 제한 | 제출 | 정답 | 맞힌 사람 | 정답 비율 |
---|---|---|---|---|---|
1 초 (추가 시간 없음) | 1024 MB (추가 메모리 없음) | 1389 | 515 | 431 | 36.869% |
한가롭게 방학에 놀고 있던 도현이는 갑자기 재밌는 자료구조를 생각해냈다. 그 자료구조의 이름은 queuestack이다.
queuestack의 구조는 다음과 같다. 번, 번, ... , 번의 자료구조(queue 혹은 stack)가 나열되어있으며, 각각의 자료구조에는 한 개의 원소가 들어있다.
queuestack의 작동은 다음과 같다.
을 입력받는다.
을 번 자료구조에 삽입한 뒤 번 자료구조에서 원소를 pop한다. 그때 pop된 원소를 이라 한다.
을 번 자료구조에 삽입한 뒤 번 자료구조에서 원소를 pop한다. 그때 pop된 원소를 이라 한다.
...
을 번 자료구조에 삽입한 뒤 번 자료구조에서 원소를 pop한다. 그때 pop된 원소를 이라 한다.
을 리턴한다.도현이는 길이 의 수열 를 가져와서 수열의 원소를 앞에서부터 차례대로 queuestack에 삽입할 것이다. 이전에 삽입한 결과는 남아 있다. (예제 참고)
queuestack에 넣을 원소들이 주어졌을 때, 해당 원소를 넣은 리턴값을 출력하는 프로그램을 작성해보자.
4
0 1 1 0
1 2 3 4
3
2 4 7
# 출력
4 1 2
들어올 값 | 1번들어온 값 | 나간 값 | 2번 | 3번 | 4번 | 큐스택 | |||
---|---|---|---|---|---|---|---|---|---|
큐 | 스택 | 스택 | 큐 | [] | |||||
1 | 2 | 3 | 4 | [] | |||||
2 | 2 | 1 | 1 | 1 | 1 | 1 | 1 | 4 | 4 |
현재 값 | 2 | 2 | 3 | 1 | 4 | ||||
4 | 4 | 2 | 2 | 2 | 2 | 2 | 2 | 1 | [4,1] |
현재 값 | 4 | 2 | 2 | 2 | 4,1 | ||||
7 | 7 | 4 | 4 | 4 | 4 | 4 | 4 | 2 | 4,1,2 |
현재 값 | [4,1,2] |
appendleft
를 사용해서 왼쪽부터 삽입해준다.pop
해서 answer에 넣는다.import sys
from collections import deque
input=sys.stdin.readline
N=int(input())
A=list(map(int,input().split())) # 0,1,1,0
B=list(map(int,input().split()))# 1,2,3,4
queuestack=[]
for idx,value in enumerate(B):
if A[idx]==0:
queuestack.append(deque([value]))
else:
queuestack.append([value])
M=int(input())
C=list(map(int,input().split()))
answer=[]
for i in range(M):
value=C[i]
for j in range(N):
if A[j]==0:
queuestack[j].append(value)
value=queuestack[j].popleft()
answer.append(value)
print(answer)
반복문 2회 사용으로 시간이 초과되었다.
import sys
from collections import deque
input=sys.stdin.readline
'''
N 자료구조 개수(~100,000)
A : 0 -> 큐 1-> 스택
B : 자료구조에 들어있는 원소 1~10억
M : 삽입할 수열의 길이 ~100000
C : 삽입할 수열.
'''
N=int(input())
A=list(map(int,input().split())) # 0,1,1,0
B=list(map(int,input().split()))# 1,2,3,4
queuestack=deque()
for idx,value in enumerate(B):
if A[idx]==0:
queuestack.append(value)
M=int(input()) # 삽입할 수열의 길이.
C=list(map(int,input().split())) # 수열의 리스트
answer=[]
for i in C:
queuestack.appendleft(i)
for _ in range(M):
answer.append(queuestack.pop())
print(*answer)
많은 것을 배웠습니다, 감사합니다.