본문 바로가기

[백준] 1966번: 프린터 큐(파이썬) https://www.acmicpc.net/problem/1966 1966번: 프린터 큐 여러분도 알다시피 여러분의 프린터 기기는 여러분이 인쇄하고자 하는 문서를 인쇄 명령을 받은 ‘순서대로’, 즉 먼저 요청된 것을 먼저 인쇄한다. 여러 개의 문서가 쌓인다면 Queue 자료구조에 www.acmicpc.net import sys from collections import deque num = int(sys.stdin.readline()) result = [] for i in range(num): ent, target = map(int,sys.stdin.readline().split()) que = list(sys.stdin.readline().rsplit()) que = deque(que) count = .. 더보기
[백준]10866번: 덱(파이썬) https://www.acmicpc.net/problem/10866 10866번: 덱 첫째 줄에 주어지는 명령의 수 N (1 ≤ N ≤ 10,000)이 주어진다. 둘째 줄부터 N개의 줄에는 명령이 하나씩 주어진다. 주어지는 정수는 1보다 크거나 같고, 100,000보다 작거나 같다. 문제에 나와있지 www.acmicpc.net from collections import deque que = deque() num = int(input()) result = [] for _ in range(num): ans = list(input().split()) if len(ans) == 2: ans[1] = int(ans[1]) if ans[0] == "push_front": que.append(ans[1]) elif .. 더보기
[백준]2164번: 카드2(파이썬) https://www.acmicpc.net/problem/2164 2164번: 카드2 N장의 카드가 있다. 각각의 카드는 차례로 1부터 N까지의 번호가 붙어 있으며, 1번 카드가 제일 위에, N번 카드가 제일 아래인 상태로 순서대로 카드가 놓여 있다. 이제 다음과 같은 동작을 카드가 www.acmicpc.net num = int(input()) que = [] for i in range(num): que.append(i+1) while len(que)>1: que.pop(0) a = que.pop(0) que.append(a) print(que[0]) 맨 처음엔 단순히 pop을 사용하여서 구현하였다. 연속된 시간 초과로 멘탈이 나가버려서 구글의 도움을 받았다. from collections import .. 더보기
[백준]10845번:큐(파이썬) https://www.acmicpc.net/problem/10845 10845번: 큐 첫째 줄에 주어지는 명령의 수 N (1 ≤ N ≤ 10,000)이 주어진다. 둘째 줄부터 N개의 줄에는 명령이 하나씩 주어진다. 주어지는 정수는 1보다 크거나 같고, 100,000보다 작거나 같다. 문제에 나와있지 www.acmicpc.net num = int(input()) que = [] result=[] for i in range(num): word = list((input().split())) if word[0] == "push": que.append(int(word[1])) elif word[0] == "pop": if que != []: a = que.pop(0) result.append(a) else: re.. 더보기