QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#673489#8783. Cherry PickingmalkovskyWA 15ms10740kbPython32.3kb2024-10-24 22:52:322024-10-24 22:52:34

Judging History

你现在查看的是最新测评结果

  • [2024-10-24 22:52:34]
  • 评测
  • 测评结果:WA
  • 用时:15ms
  • 内存:10740kb
  • [2024-10-24 22:52:32]
  • 提交

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'