CSES - Datatähti 2022 alku - Results
Submission details
Task:Ositus
Sender:okkokko
Submission time:2021-10-07 20:11:42 +0300
Language:Python3 (CPython3)
Status:READY
Result:65
Feedback
groupverdictscore
#1ACCEPTED40
#2ACCEPTED25
#30
Test results
testverdicttimegroup
#1ACCEPTED0.02 s1, 2, 3details
#2ACCEPTED0.02 s1, 2, 3details
#3ACCEPTED0.02 s1, 2, 3details
#4ACCEPTED0.02 s1, 2, 3details
#5ACCEPTED0.02 s2, 3details
#6ACCEPTED0.05 s3details
#7--3details

Code

def noOverlaps(a,b):
    for i in range(len(a)):
        if b.find(a[i])!=-1:
            return False
    return True

# U=input()
#I="aybabtu"
# ends={0:1}
# for i in range(len(I)):
    # s=I[i]
    # newEnds={i:0}
    # k=i
    # while k!=-1:
    #     newEnds[i]+=ends[k]
    #     if s==I[k]:
    #         k=-1
    #     else:
    #         sortEnd=k
    #         newEnds.setdefault(sortEnd,0)
    #         newEnds[sortEnd]+=ends[k]
    #         k-=1
    # ends=newEnds
    # print(ends)

# ends={}
# for i in range(len(I)):
#     print(i)
#     s=I[i]
#     cut = I.rfind(s,0,i)
#     newEnds={i:0}
#     for j in range(i):
#         if j>cut:
#             newEnds[j] = ends[j]
#         newEnds[i] +=ends[j]
    
#     ends=newEnds
#     print(ends)

I="aybabtu"
I=input()
ends={0:1}
for i in range(1,len(I)):
    s=I[i]
    newEnds={i:0}
    cut=I.rfind(s,0,i)
    for k in ends.keys():
        if k>cut: #I.find(s,k,i)==-1:
            sortEnd=k
            newEnds.setdefault(sortEnd,0)
            newEnds[sortEnd]+=ends[k]
        newEnds[i]+=ends[k]
    ends=newEnds
    # print(ends)



total=0
for k in ends.keys():
    total+=ends[k]
print(total%(7+(10**9)))

Test details

Test 1

Group: 1, 2, 3

Verdict: ACCEPTED

input
a

correct output
1

user output
1

Test 2

Group: 1, 2, 3

Verdict: ACCEPTED

input
abcdefghij

correct output
512

user output
512

Test 3

Group: 1, 2, 3

Verdict: ACCEPTED

input
abcabaacbc

correct output
120

user output
120

Test 4

Group: 1, 2, 3

Verdict: ACCEPTED

input
aaxxxxxxaa

correct output
4

user output
4

Test 5

Group: 2, 3

Verdict: ACCEPTED

input
mfyzvoxmppoxcvktmcjkryyocfweub...

correct output
643221148

user output
643221148

Test 6

Group: 3

Verdict: ACCEPTED

input
weinscqmmpgbrlboocvtbptgbahmwv...

correct output
831644159

user output
831644159

Test 7

Group: 3

Verdict:

input
sxaoxcyrjoeieyinaqxwukgzdnhhsw...

correct output
816016015

user output
(empty)