白駿#1966プリンタキュー
1.質問
https://www.acmicpc.net/problem/1966
data:image/s3,"s3://crabby-images/6f452/6f4529f539fcf6d1e40359ac4c8da1fa6d32328c" alt=""
data:image/s3,"s3://crabby-images/3e269/3e269e56126ae0bb449752714c7d06341ba6666f" alt=""
2.私の回答
2-1. に答える
data:image/s3,"s3://crabby-images/eb4e0/eb4e0d19b2048bcf7d3f0222c6f2fda5113b6593" alt=""
import sys
n = int(sys.stdin.readline().split()[0])
for i in range(n):
doc_count, target = [int(x) for x in sys.stdin.readline().split()]
list = [int(x) for x in sys.stdin.readline().split()]
new_list = [{'index': index, 'value': value} for index, value in enumerate(list)]
rlt = []
while new_list:
if new_list[0]['value'] == max([x['value'] for x in new_list]):
rlt.append(new_list.pop(0))
else:
new_list.append(new_list.pop(0))
count = 0
for r in rlt:
count += 1
if r['index'] == target:
break
print(count)
問題をよく読んで実施すればいいのですが、いつも間違っていて、時間しかかかりませんでした.
ううう
3.他人の回答
data:image/s3,"s3://crabby-images/40d7c/40d7caffdda4ed2fe246a62a08c928d321ae571a" alt=""
test_case = int(input())
for _ in range(test_case):
n, m = list(map(int, input().split(' ')))
queue = list(map(int, input().split(' ')))
queue = [(i, idx) for idx, i in enumerate(queue)]
count = 0
while True:
if queue[0][0] == max(queue, key=lambda x: x[0])[0]:
count += 1
if queue[0][1] == m:
print(count)
break
else:
queue.pop(0)
else:
queue.append(queue.pop(0))
4.感じ
Reference
この問題について(白駿#1966プリンタキュー), 我々は、より多くの情報をここで見つけました https://velog.io/@muchogusto/백준1966-프린터-큐テキストは自由に共有またはコピーできます。ただし、このドキュメントのURLは参考URLとして残しておいてください。
Collection and Share based on the CC Protocol