| Task: | Robotti | 
| Sender: | Ihminen | 
| Submission time: | 2024-10-29 20:38:38 +0200 | 
| Language: | Python3 (PyPy3) | 
| Status: | READY | 
| Result: | 0 | 
| group | verdict | score | 
|---|---|---|
| #1 | WRONG ANSWER | 0 | 
| #2 | WRONG ANSWER | 0 | 
| test | verdict | time | group | |
|---|---|---|---|---|
| #1 | ACCEPTED | 0.04 s | 1, 2 | details | 
| #2 | ACCEPTED | 0.04 s | 1, 2 | details | 
| #3 | WRONG ANSWER | 0.04 s | 1, 2 | details | 
| #4 | ACCEPTED | 0.04 s | 1, 2 | details | 
| #5 | WRONG ANSWER | 0.04 s | 1, 2 | details | 
| #6 | TIME LIMIT EXCEEDED | -- | 1, 2 | details | 
| #7 | TIME LIMIT EXCEEDED | -- | 1, 2 | details | 
| #8 | ACCEPTED | 0.04 s | 1, 2 | details | 
| #9 | ACCEPTED | 0.04 s | 1, 2 | details | 
| #10 | WRONG ANSWER | 0.04 s | 1, 2 | details | 
| #11 | TIME LIMIT EXCEEDED | -- | 1, 2 | details | 
| #12 | WRONG ANSWER | 0.05 s | 2 | details | 
| #13 | TIME LIMIT EXCEEDED | -- | 2 | details | 
| #14 | TIME LIMIT EXCEEDED | -- | 2 | details | 
| #15 | WRONG ANSWER | 0.04 s | 2 | details | 
| #16 | TIME LIMIT EXCEEDED | -- | 2 | details | 
| #17 | ACCEPTED | 0.05 s | 2 | details | 
| #18 | WRONG ANSWER | 0.06 s | 2 | details | 
| #19 | TIME LIMIT EXCEEDED | -- | 2 | details | 
| #20 | ACCEPTED | 0.05 s | 2 | details | 
| #21 | WRONG ANSWER | 0.04 s | 2 | details | 
| #22 | WRONG ANSWER | 0.04 s | 2 | details | 
| #23 | WRONG ANSWER | 0.04 s | 2 | details | 
| #24 | TIME LIMIT EXCEEDED | -- | 2 | details | 
Code
n = int(input())
huoneet = input()
robottiIndex = 0
robottiListaIndex = 0
kerätytKolikot = 0
askel = 0
jääty = 0
kolikkojenSijainnit = []
for i in range(n):
    if huoneet[i] == '*':
        kolikkojenSijainnit.append(i)
    elif huoneet[i] == 'R':
        jääty = i
        robottiIndex = i
        robottiListaIndex = len(kolikkojenSijainnit)
        break
jumissa = False
if kolikkojenSijainnit == []:
    jumissa = True
def wombokombo(rIndex, kolikot, askeleet, junttura, jatka, rlIndex):
    jatka = False
    #print(kolikkojenSijainnit)
    #print(kolikkojenSijainnit[rlIndex-1], kolikkojenSijainnit[rlIndex])
    #print()
    a = kolikkojenSijainnit[rlIndex-1] - rIndex
    b = kolikkojenSijainnit[rlIndex] - rIndex
    a_abs = abs(a)
    b_abs = abs(b)
    #print(a_abs, b_abs)
    pakkoOikea = False
    if (a_abs == b_abs):
        junttura = True
    elif (a_abs < b_abs):
        rIndex -= a_abs
        kolikot += 1
        askeleet += a_abs
        kolikkojenSijainnit.pop(rlIndex-1)
        rlIndex -= 1
        #print("rlIndex: ", rlIndex)
    elif (b_abs < a_abs):
        rIndex += b_abs
        kolikot += 1
        askeleet += b_abs
        #print("rlIndex: ", rlIndex)
        kolikkojenSijainnit.pop(rlIndex)
        pakkoOikea = True
    #print("Jatkettava: ", kolikkojenSijainnit)
    if not pakkoOikea:
        a = kolikkojenSijainnit[rlIndex - 1] - rIndex
        b = kolikkojenSijainnit[rlIndex] - rIndex
        a_abs = abs(a)
        b_abs = abs(b)
        if (a_abs < b_abs):
            #print("Voidaan jatkaa.")
            jatka = True
        elif (a_abs == b_abs):
            #print("Jumissa ollaan!")
            jumissa
    return rIndex, kolikot, askeleet, junttura, jatka, rlIndex
while not jumissa:
    for i in range(jääty, n):
        if huoneet[i] == '*':
            jääty = i
            #print("Jääty:", jääty)
            kolikkojenSijainnit.append(i)
            jatketaan = True
            while jatketaan:
                robottiIndex, kerätytKolikot, askel, jumissa, jatketaan, robottiListaIndex = wombokombo(robottiIndex, kerätytKolikot, askel, jumissa, jatketaan, robottiListaIndex)
            if jumissa:
                break
print(askel, kerätytKolikot)Test details
Test 1
Group: 1, 2
Verdict: ACCEPTED
| input | 
|---|
| 1 R  | 
| correct output | 
|---|
| 0 0 | 
| user output | 
|---|
| 0 0 | 
Test 2
Group: 1, 2
Verdict: ACCEPTED
| input | 
|---|
| 10 ...R......  | 
| correct output | 
|---|
| 0 0 | 
| user output | 
|---|
| 0 0 | 
Test 3
Group: 1, 2
Verdict: WRONG ANSWER
| input | 
|---|
| 10 **.R...***  | 
| correct output | 
|---|
| 12 5 | 
| user output | 
|---|
| 11 4 | 
Test 4
Group: 1, 2
Verdict: ACCEPTED
| input | 
|---|
| 10 ***R******  | 
| correct output | 
|---|
| 0 0 | 
| user output | 
|---|
| 0 0 | 
Test 5
Group: 1, 2
Verdict: WRONG ANSWER
| input | 
|---|
| 1000 R................................  | 
| correct output | 
|---|
| 947 9 | 
| user output | 
|---|
| 0 0 | 
Test 6
Group: 1, 2
Verdict: TIME LIMIT EXCEEDED
| input | 
|---|
| 1000 .................................  | 
| correct output | 
|---|
| 886 9 | 
| user output | 
|---|
| (empty) | 
Test 7
Group: 1, 2
Verdict: TIME LIMIT EXCEEDED
| input | 
|---|
| 1000 .....*..*....**..**..*......*....  | 
| correct output | 
|---|
| 1287 400 | 
| user output | 
|---|
| (empty) | 
Test 8
Group: 1, 2
Verdict: ACCEPTED
| input | 
|---|
| 1000 ************.*****************...  | 
| correct output | 
|---|
| 0 0 | 
| user output | 
|---|
| 0 0 | 
Test 9
Group: 1, 2
Verdict: ACCEPTED
| input | 
|---|
| 1000 ******************************...  | 
| correct output | 
|---|
| 0 0 | 
| user output | 
|---|
| 0 0 | 
Test 10
Group: 1, 2
Verdict: WRONG ANSWER
| input | 
|---|
| 1000 R*****************************...  | 
| correct output | 
|---|
| 999 999 | 
| user output | 
|---|
| 0 0 | 
Test 11
Group: 1, 2
Verdict: TIME LIMIT EXCEEDED
| input | 
|---|
| 1000 ******************************...  | 
| correct output | 
|---|
| 999 999 | 
| user output | 
|---|
| (empty) | 
Test 12
Group: 2
Verdict: WRONG ANSWER
| input | 
|---|
| 10000 .......**........*...........*...  | 
| correct output | 
|---|
| 10971 999 | 
| user output | 
|---|
| 10925 998 | 
Test 13
Group: 2
Verdict: TIME LIMIT EXCEEDED
| input | 
|---|
| 10000 *..*....*......*.....*..*........  | 
| correct output | 
|---|
| 9999 999 | 
| user output | 
|---|
| (empty) | 
Test 14
Group: 2
Verdict: TIME LIMIT EXCEEDED
| input | 
|---|
| 10000 *.*.*...**.*...*....**.**.**.....  | 
| correct output | 
|---|
| 18766 5000 | 
| user output | 
|---|
| (empty) | 
Test 15
Group: 2
Verdict: WRONG ANSWER
| input | 
|---|
| 10000 R*****************************...  | 
| correct output | 
|---|
| 9999 9999 | 
| user output | 
|---|
| 0 0 | 
Test 16
Group: 2
Verdict: TIME LIMIT EXCEEDED
| input | 
|---|
| 10000 ******************************...  | 
| correct output | 
|---|
| 9999 9999 | 
| user output | 
|---|
| (empty) | 
Test 17
Group: 2
Verdict: ACCEPTED
| input | 
|---|
| 200000 .................................  | 
| correct output | 
|---|
| 0 0 | 
| user output | 
|---|
| 0 0 | 
Test 18
Group: 2
Verdict: WRONG ANSWER
| input | 
|---|
| 200000 .................................  | 
| correct output | 
|---|
| 299934 10000 | 
| user output | 
|---|
| 299929 9999 | 
Test 19
Group: 2
Verdict: TIME LIMIT EXCEEDED
| input | 
|---|
| 200000 **.***....**..**.....***.*..*....  | 
| correct output | 
|---|
| 299998 100000 | 
| user output | 
|---|
| (empty) | 
Test 20
Group: 2
Verdict: ACCEPTED
| input | 
|---|
| 200000 ******************************...  | 
| correct output | 
|---|
| 0 0 | 
| user output | 
|---|
| 0 0 | 
Test 21
Group: 2
Verdict: WRONG ANSWER
| input | 
|---|
| 200000 R................................  | 
| correct output | 
|---|
| 133765 3 | 
| user output | 
|---|
| 0 0 | 
Test 22
Group: 2
Verdict: WRONG ANSWER
| input | 
|---|
| 200000 R................................  | 
| correct output | 
|---|
| 199982 5000 | 
| user output | 
|---|
| 0 0 | 
Test 23
Group: 2
Verdict: WRONG ANSWER
| input | 
|---|
| 200000 R*****************************...  | 
| correct output | 
|---|
| 199999 199999 | 
| user output | 
|---|
| 0 0 | 
Test 24
Group: 2
Verdict: TIME LIMIT EXCEEDED
| input | 
|---|
| 200000 ******************************...  | 
| correct output | 
|---|
| 199999 199999 | 
| user output | 
|---|
| (empty) | 
