QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#673489 | #8783. Cherry Picking | malkovsky | WA | 15ms | 10740kb | Python3 | 2.3kb | 2024-10-24 22:52:32 | 2024-10-24 22:52:34 |
Judging History
answer
def __main__():
sorted_players = dict()
n, k = map(int, input().split())
ratings = list(map(int, input().split()))
result = input()
left = [i for i in range(n)]
def get_left(i):
while i != left[i]:
i = left[i]
return left[i]
right = [i + 1 for i in range(n)]
size = [1 for i in range(n)]
num_at_least_k = 0
for i in range(0, n):
if i > 0 and result[i] == result[i - 1]:
left[i] = left[i - 1]
right[left[i]] = right[i]
size[left[i]] += 1
if size[left[i]] == k and result[i] == "1":
num_at_least_k += 1
if k == 1:
num_at_least_k += int(result[i])
if ratings[i] not in sorted_players:
sorted_players[ratings[i]] = []
sorted_players[ratings[i]].append(i)
# print(left,right, size)
# print(num_at_least_k)
answer = 0
lower = 0
upper = n
for r, players in sorted(sorted_players.items(), key=lambda x: x[0]):
if num_at_least_k > 0:
answer = r
# print(r, num_at_least_k)
for player in players:
seg = get_left(player)
size[seg] -= 1
if size[seg] == k - 1 and result[seg] == "1":
num_at_least_k -= 1
# print("removed", player, seg, size[seg])
if size[seg] == 0:
# print(seg, right[seg], lower, upper)
if right[seg] < upper and seg > lower:
# print(left, right)
left[right[seg]] = get_left(seg - 1)
right[left[right[seg]]] = right[right[seg]]
size[left[right[seg]]] += size[right[seg]]
# print("Merged", left[right[seg]], right[right[seg]], size[left[right[seg]]])
if size[left[right[seg]]] >= k and result[left[right[seg]]] == "1":
num_at_least_k += 1
if seg == lower:
# print("junked", lower, right[seg])
lower = right[seg]
if right[seg] == r:
# print("junked", seg, upper)
upper = seg
# print(num_at_least_k)
print(answer)
__main__()
详细
Test #1:
score: 100
Accepted
time: 11ms
memory: 10740kb
input:
5 2 1 2 3 4 5 01101
output:
2
result:
ok answer is '2'
Test #2:
score: 0
Accepted
time: 5ms
memory: 10704kb
input:
5 2 3 4 5 2 1 10101
output:
0
result:
ok answer is '0'
Test #3:
score: 0
Accepted
time: 11ms
memory: 10624kb
input:
1 1 1 1
output:
1
result:
ok answer is '1'
Test #4:
score: 0
Accepted
time: 11ms
memory: 10580kb
input:
1 1 1 0
output:
0
result:
ok answer is '0'
Test #5:
score: 0
Accepted
time: 15ms
memory: 10700kb
input:
5 3 8 3 5 2 7 10101
output:
5
result:
ok answer is '5'
Test #6:
score: 0
Accepted
time: 15ms
memory: 10592kb
input:
10 3 1 10 2 3 9 3 1 6 9 3 1100110001
output:
0
result:
ok answer is '0'
Test #7:
score: 0
Accepted
time: 9ms
memory: 10740kb
input:
10 1 6 7 2 10 8 4 4 9 7 9 0111011000
output:
10
result:
ok answer is '10'
Test #8:
score: 0
Accepted
time: 3ms
memory: 10572kb
input:
10 2 4 5 9 6 9 10 6 9 2 7 1100010100
output:
9
result:
ok answer is '9'
Test #9:
score: 0
Accepted
time: 3ms
memory: 10648kb
input:
10 3 2 10 8 5 8 3 7 9 9 1 1100011100
output:
3
result:
ok answer is '3'
Test #10:
score: 0
Accepted
time: 9ms
memory: 10628kb
input:
10 5 5 5 9 2 7 2 4 8 4 8 1010001100
output:
0
result:
ok answer is '0'
Test #11:
score: 0
Accepted
time: 11ms
memory: 10592kb
input:
10 10 6 5 8 3 2 8 6 4 5 5 0111001100
output:
0
result:
ok answer is '0'
Test #12:
score: -100
Wrong Answer
time: 14ms
memory: 10544kb
input:
100 1 13 90 87 79 34 66 76 58 65 37 63 38 84 88 89 98 63 55 16 39 64 50 28 64 4 69 40 51 75 37 11 9 20 29 36 29 30 61 38 54 92 78 72 36 78 24 78 8 98 11 2 41 64 51 45 67 27 80 67 84 73 50 99 82 39 70 84 18 54 43 85 96 59 98 82 5 57 46 68 31 97 89 21 65 57 37 58 25 30 40 15 76 44 85 75 65 22 97 93 82...
output:
99
result:
wrong answer expected '97', found '99'