CSES - Aalto Competitive Programming 2024 - wk9 - Mon - Results
Submission details
Task:Matter++
Sender:esya_rae
Submission time:2024-11-04 17:29:59 +0200
Language:Python3 (PyPy3)
Status:READY
Result:ACCEPTED
Test results
testverdicttime
#1ACCEPTED0.04 sdetails
#2ACCEPTED0.04 sdetails
#3ACCEPTED0.04 sdetails
#4ACCEPTED0.04 sdetails
#5ACCEPTED0.04 sdetails
#6ACCEPTED0.04 sdetails
#7ACCEPTED0.04 sdetails
#8ACCEPTED0.04 sdetails
#9ACCEPTED0.04 sdetails
#10ACCEPTED0.04 sdetails
#11ACCEPTED0.04 sdetails
#12ACCEPTED0.04 sdetails
#13ACCEPTED0.04 sdetails
#14ACCEPTED0.04 sdetails
#15ACCEPTED0.05 sdetails
#16ACCEPTED0.04 sdetails
#17ACCEPTED0.04 sdetails
#18ACCEPTED0.04 sdetails
#19ACCEPTED0.04 sdetails
#20ACCEPTED0.04 sdetails
#21ACCEPTED0.04 sdetails
#22ACCEPTED0.04 sdetails
#23ACCEPTED0.04 sdetails
#24ACCEPTED0.04 sdetails
#25ACCEPTED0.04 sdetails
#26ACCEPTED0.04 sdetails
#27ACCEPTED0.04 sdetails
#28ACCEPTED0.04 sdetails
#29ACCEPTED0.04 sdetails
#30ACCEPTED0.05 sdetails
#31ACCEPTED0.04 sdetails
#32ACCEPTED0.05 sdetails
#33ACCEPTED0.05 sdetails
#34ACCEPTED0.05 sdetails
#35ACCEPTED0.05 sdetails
#36ACCEPTED0.05 sdetails
#37ACCEPTED0.05 sdetails
#38ACCEPTED0.05 sdetails
#39ACCEPTED0.05 sdetails
#40ACCEPTED0.05 sdetails
#41ACCEPTED0.05 sdetails
#42ACCEPTED0.05 sdetails
#43ACCEPTED0.05 sdetails
#44ACCEPTED0.05 sdetails
#45ACCEPTED0.05 sdetails
#46ACCEPTED0.05 sdetails
#47ACCEPTED0.05 sdetails
#48ACCEPTED0.05 sdetails
#49ACCEPTED0.05 sdetails
#50ACCEPTED0.05 sdetails
#51ACCEPTED0.05 sdetails
#52ACCEPTED0.06 sdetails
#53ACCEPTED0.06 sdetails
#54ACCEPTED0.06 sdetails
#55ACCEPTED0.06 sdetails
#56ACCEPTED0.06 sdetails
#57ACCEPTED0.06 sdetails
#58ACCEPTED0.06 sdetails
#59ACCEPTED0.05 sdetails
#60ACCEPTED0.06 sdetails
#61ACCEPTED0.06 sdetails
#62ACCEPTED0.21 sdetails
#63ACCEPTED0.20 sdetails
#64ACCEPTED0.20 sdetails
#65ACCEPTED0.20 sdetails
#66ACCEPTED0.21 sdetails
#67ACCEPTED0.20 sdetails
#68ACCEPTED0.20 sdetails
#69ACCEPTED0.20 sdetails
#70ACCEPTED0.20 sdetails
#71ACCEPTED0.20 sdetails

Code

import sys
input = sys.stdin.readline

def to_num(c):
    return ord(c) - ord('a')


w = int(input())
s = input().strip()
n = len(s)
cur_w = 0


frequency = [[0] * 26 for _ in range(n + 1)]
# ww = [0] * n
# ww[0] = 1
for i in range(1, n + 1):
    frequency[i] = frequency[i - 1].copy()
    frequency[i][to_num(s[i - 1])] += 1
    # if i != 0:
    #     ww[i] = ww[i - 1] + 2 * frequency[i][to_num(s[i])] - 1
# print(frequency)
left_s = -1
right_s = n
left = 0
right = -1
cur_w = 0
while right < n - 1 or cur_w > w:
    if cur_w > w:
        left += 1
    else:
        right += 1
    cur_w = 0
    # print(left, right)
    for i in range(26):
        cur_w += (frequency[right + 1][i] - frequency[left][i]) ** 2
    # print(cur_w)
    if cur_w >= w and right - left < right_s - left_s:
        # print('here')
        left_s = left
        right_s = right

print(s[left_s:right_s + 1])

Test details

Test 1

Verdict: ACCEPTED

input
1
e

correct output
e

user output
e

Test 2

Verdict: ACCEPTED

input
1
be

correct output
b

user output
b

Test 3

Verdict: ACCEPTED

input
1
za

correct output
z

user output
z

Test 4

Verdict: ACCEPTED

input
1
po

correct output
p

user output
p

Test 5

Verdict: ACCEPTED

input
1
acc

correct output
a

user output
a

Test 6

Verdict: ACCEPTED

input
2
caa

correct output
ca

user output
ca

Test 7

Verdict: ACCEPTED

input
2
caa

correct output
ca

user output
ca

Test 8

Verdict: ACCEPTED

input
2
cced

correct output
cc

user output
cc

Test 9

Verdict: ACCEPTED

input
2
ceea

correct output
ce

user output
ce

Test 10

Verdict: ACCEPTED

input
1
ccad

correct output
c

user output
c

Test 11

Verdict: ACCEPTED

input
4
ccda

correct output
cc

user output
cc

Test 12

Verdict: ACCEPTED

input
1
defdf

correct output
d

user output
d

Test 13

Verdict: ACCEPTED

input
1
fefaa

correct output
f

user output
f

Test 14

Verdict: ACCEPTED

input
7
bafdf

correct output
bafdf

user output
bafdf

Test 15

Verdict: ACCEPTED

input
1
aefba

correct output
a

user output
a

Test 16

Verdict: ACCEPTED

input
3
cbacc

correct output
cc

user output
cc

Test 17

Verdict: ACCEPTED

input
1
bwvfj

correct output
b

user output
b

Test 18

Verdict: ACCEPTED

input
11
caaca

correct output
caaca

user output
caaca

Test 19

Verdict: ACCEPTED

input
4
fuilz

correct output
fuil

user output
fuil

Test 20

Verdict: ACCEPTED

input
5
acacb

correct output
aca

user output
aca

Test 21

Verdict: ACCEPTED

input
4
jnmma

correct output
mm

user output
mm

Test 22

Verdict: ACCEPTED

input
6
defdfdfcdd

correct output
defd

user output
defd

Test 23

Verdict: ACCEPTED

input
5
fefaabfaba

correct output
fef

user output
fef

Test 24

Verdict: ACCEPTED

input
22
bafdfcccbb

correct output
bafdfcccbb

user output
bafdfcccbb

Test 25

Verdict: ACCEPTED

input
12
aefbaddfcf

correct output
aefbaddf

user output
aefbaddf

Test 26

Verdict: ACCEPTED

input
14
cbacccbcba

correct output
cccbc

user output
cccbc

Test 27

Verdict: ACCEPTED

input
1
bwvfjxzmcp

correct output
b

user output
b

Test 28

Verdict: ACCEPTED

input
17
caacaabacb

correct output
aacaa

user output
aacaa

Test 29

Verdict: ACCEPTED

input
13
fuilzslzio

correct output
ilzslzi

user output
ilzslzi

Test 30

Verdict: ACCEPTED

input
16
acacbbcaba

correct output
acacbbc

user output
acacbbc

Test 31

Verdict: ACCEPTED

input
5
jnmmadidaf

correct output
nmm

user output
nmm

Test 32

Verdict: ACCEPTED

input
278
defdfdfcddccbfafbcceedcdcffaca...

correct output
fdfcddccbfafbcceedcdcffacadace...

user output
fdfcddccbfafbcceedcdcffacadace...

Test 33

Verdict: ACCEPTED

input
32
fefaabfabacbccecfdfcbedbcfbade...

correct output
cbccecfdfc

user output
cbccecfdfc

Test 34

Verdict: ACCEPTED

input
1387
bafdfcccbbabedabcbddedeacddbee...

correct output
dfcccbbabedabcbddedeacddbeebfd...

user output
dfcccbbabedabcbddedeacddbeebfd...

Test 35

Verdict: ACCEPTED

input
190
aefbaddfcfaaabbaaceaaccdbbcecd...

correct output
aaabbaaceaaccdbbcecdfaedfbccdb...

user output
aaabbaaceaaccdbbcecdfaedfbccdb...

Test 36

Verdict: ACCEPTED

input
1205
cbacccbcbaacaacacbbcaabcbcbabb...

correct output
abbaabccbacacccbabaabaacccbcbc...

user output
abbaabccbacacccbabaabaacccbcbc...

Test 37

Verdict: ACCEPTED

input
299
bwvfjxzmcpktjnmhzevcqtvlgetwch...

correct output
vfjxzmcpktjnmhzevcqtvlgetwchfk...

user output
vfjxzmcpktjnmhzevcqtvlgetwchfk...

Test 38

Verdict: ACCEPTED

input
2796
caacaabacbabbbbbbbcbccbbababcc...

correct output
bacbabbbbbbbcbccbbababccccbbcc...

user output
bacbabbbbbbbcbccbbababccccbbcc...

Test 39

Verdict: ACCEPTED

input
345
fuilzslziogncbkgamnrwuijkbrhrx...

correct output
lziogncbkgamnrwuijkbrhrxsfilyy...

user output
lziogncbkgamnrwuijkbrhrxsfilyy...

Test 40

Verdict: ACCEPTED

input
1517
acacbbcababbcbbbcbcbabccbccbab...

correct output
baaaaaccaaaaababbccbbccaaababb...

user output
baaaaaccaaaaababbccbbccaaababb...

Test 41

Verdict: ACCEPTED

input
123
jnmmadidafwkdgdckimeiwjytbzsso...

correct output
mmadidafwkdgdckimeiwjytbzssodx...

user output
mmadidafwkdgdckimeiwjytbzssodx...

Test 42

Verdict: ACCEPTED

input
1079
defdfdfcddccbfafbcceedcdcffaca...

correct output
fdfdfcddccbfafbcceedcdcffacada...

user output
fdfdfcddccbfafbcceedcdcffacada...

Test 43

Verdict: ACCEPTED

input
56
fefaabfabacbccecfdfcbedbcfbade...

correct output
fbeeefebaedfff

user output
fbeeefebaedfff

Test 44

Verdict: ACCEPTED

input
5337
bafdfcccbbabedabcbddedeacddbee...

correct output
bafdfcccbbabedabcbddedeacddbee...

user output
bafdfcccbbabedabcbddedeacddbee...

Test 45

Verdict: ACCEPTED

input
744
aefbaddfcfaaabbaaceaaccdbbcecd...

correct output
cccacdedecabbcdcebdbbcdfddfbeb...

user output
cccacdedecabbcdcebdbbcdfddfbeb...

Test 46

Verdict: ACCEPTED

input
10488
cbacccbcbaacaacacbbcaabcbcbabb...

correct output
bcbcbabbcabbaabccbacacccbabaab...

user output
bcbcbabbcabbaabccbacacccbabaab...

Test 47

Verdict: ACCEPTED

input
11
bwvfjxzmcpktjnmhzevcqtvlgetwch...

correct output
pxyyy

user output
pxyyy

Test 48

Verdict: ACCEPTED

input
5929
caacaabacbabbbbbbbcbccbbababcc...

correct output
bbbbbbbcbccbbababccccbbccccbac...

user output
bbbbbbbcbccbbababccccbbccccbac...

Test 49

Verdict: ACCEPTED

input
1398
fuilzslziogncbkgamnrwuijkbrhrx...

correct output
gncbkgamnrwuijkbrhrxsfilyygatp...

user output
gncbkgamnrwuijkbrhrxsfilyygatp...

Test 50

Verdict: ACCEPTED

input
5219
acacbbcababbcbbbcbcbabccbccbab...

correct output
acbbcababbcbbbcbcbabccbccbabba...

user output
acbbcababbcbbbcbcbabccbccbabba...

Test 51

Verdict: ACCEPTED

input
450
jnmmadidafwkdgdckimeiwjytbzsso...

correct output
qmtyjuvzcecnbymqfwyzzergpwuxbt...

user output
qmtyjuvzcecnbymqfwyzzergpwuxbt...

Test 52

Verdict: ACCEPTED

input
26679
defdfdfcddccbfafbcceedcdcffaca...

correct output
bcbfacacffbedecaafcecffaffaadd...

user output
bcbfacacffbedecaafcecffaffaadd...

Test 53

Verdict: ACCEPTED

input
22417
fefaabfabacbccecfdfcbedbcfbade...

correct output
adefccdcafbeeefebaedfffeaeabba...

user output
adefccdcafbeeefebaedfffeaeabba...

Test 54

Verdict: ACCEPTED

input
128464
bafdfcccbbabedabcbddedeacddbee...

correct output
bafdfcccbbabedabcbddedeacddbee...

user output
bafdfcccbbabedabcbddedeacddbee...

Test 55

Verdict: ACCEPTED

input
10769
aefbaddfcfaaabbaaceaaccdbbcecd...

correct output
ebefdceecdabceccdeaebdeebdcdfa...

user output
ebefdceecdabceccdeaebdeebdcdfa...

Test 56

Verdict: ACCEPTED

input
70653
cbacccbcbaacaacacbbcaabcbcbabb...

correct output
acaaaaaabaaabbccbabbbbcacbccbc...

user output
acaaaaaabaaabbccbabbbbcacbccbc...

Test 57

Verdict: ACCEPTED

input
233
bwvfjxzmcpktjnmhzevcqtvlgetwch...

correct output
qfvyojqjvhyfxtvycrjlaoofuebvev...

user output
qfvyojqjvhyfxtvycrjlaoofuebvev...

Test 58

Verdict: ACCEPTED

input
116525
caacaabacbabbbbbbbcbccbbababcc...

correct output
caaabbacabbbabcccbacaaacaaccac...

user output
caaabbacabbbabcccbacaaacaaccac...

Test 59

Verdict: ACCEPTED

input
27985
fuilzslziogncbkgamnrwuijkbrhrx...

correct output
uilzslziogncbkgamnrwuijkbrhrxs...

user output
uilzslziogncbkgamnrwuijkbrhrxs...

Test 60

Verdict: ACCEPTED

input
161959
acacbbcababbcbbbcbcbabccbccbab...

correct output
acacbbcababbcbbbcbcbabccbccbab...

user output
acacbbcababbcbbbcbcbabccbccbab...

Test 61

Verdict: ACCEPTED

input
8903
jnmmadidafwkdgdckimeiwjytbzsso...

correct output
uaguxmabjxfuialfmskifofagvsnkn...

user output
uaguxmabjxfuialfmskifofagvsnkn...

Test 62

Verdict: ACCEPTED

input
264240357
defdfdfcddccbfafbcceedcdcffaca...

correct output
badeaccfbabfcceaabffecbffcdcfe...

user output
badeaccfbabfcceaabffecbffcdcfe...

Test 63

Verdict: ACCEPTED

input
30437082
fefaabfabacbccecfdfcbedbcfbade...

correct output
acdbbfafacdebdefccfbcfcdeecdfd...

user output
acdbbfafacdebdefccfbcfcdeecdfd...

Test 64

Verdict: ACCEPTED

input
1280505429
bafdfcccbbabedabcbddedeacddbee...

correct output
eaceacebbcdfacddcecfceccddfcac...

user output
eaceacebbcdfacddcecfceccddfcac...

Test 65

Verdict: ACCEPTED

input
107609709
aefbaddfcfaaabbaaceaaccdbbcecd...

correct output
bffcffbddbfedcccfcdcdfecbbefbe...

user output
bffcffbddbfedcccfcdcdfecbbefbe...

Test 66

Verdict: ACCEPTED

input
706196896
cbacccbcbaacaacacbbcaabcbcbabb...

correct output
bccbccccacabcacaaabcccbacbcaba...

user output
bccbccccacabcacaaabcccbacbcaba...

Test 67

Verdict: ACCEPTED

input
9966992
bwvfjxzmcpktjnmhzevcqtvlgetwch...

correct output
hljwtcgatnetpvfxeiipnhaarsejbf...

user output
hljwtcgatnetpvfxeiipnhaarsejbf...

Test 68

Verdict: ACCEPTED

input
1449002782
caacaabacbabbbbbbbcbccbbababcc...

correct output
acbaabcaababcabcccabcbbaacccca...

user output
acbaabcaababcabcccabcbbaacccca...

Test 69

Verdict: ACCEPTED

input
275504573
fuilzslziogncbkgamnrwuijkbrhrx...

correct output
lziogncbkgamnrwuijkbrhrxsfilyy...

user output
lziogncbkgamnrwuijkbrhrxsfilyy...

Test 70

Verdict: ACCEPTED

input
1480920774
acacbbcababbcbbbcbcbabccbccbab...

correct output
bcccaccabcaabccaaabcbbacbbbbba...

user output
bcccaccabcaabccaaabcbbacbbbbba...

Test 71

Verdict: ACCEPTED

input
199518168
jnmmadidafwkdgdckimeiwjytbzsso...

correct output
mzdiyihtesgshxbshryvzqghavzgrs...

user output
mzdiyihtesgshxbshryvzqghavzgrs...