Task: | Robotti |
Sender: | hasorez |
Submission time: | 2024-10-28 20:14:06 +0200 |
Language: | Python3 (PyPy3) |
Status: | READY |
Result: | 30 |
group | verdict | score |
---|---|---|
#1 | ACCEPTED | 30 |
#2 | TIME LIMIT EXCEEDED | 0 |
test | verdict | time | group | |
---|---|---|---|---|
#1 | ACCEPTED | 0.04 s | 1, 2 | details |
#2 | ACCEPTED | 0.04 s | 1, 2 | details |
#3 | ACCEPTED | 0.04 s | 1, 2 | details |
#4 | ACCEPTED | 0.04 s | 1, 2 | details |
#5 | ACCEPTED | 0.04 s | 1, 2 | details |
#6 | ACCEPTED | 0.05 s | 1, 2 | details |
#7 | ACCEPTED | 0.05 s | 1, 2 | details |
#8 | ACCEPTED | 0.04 s | 1, 2 | details |
#9 | ACCEPTED | 0.04 s | 1, 2 | details |
#10 | ACCEPTED | 0.05 s | 1, 2 | details |
#11 | ACCEPTED | 0.05 s | 1, 2 | details |
#12 | ACCEPTED | 0.11 s | 2 | details |
#13 | ACCEPTED | 0.10 s | 2 | details |
#14 | ACCEPTED | 0.97 s | 2 | details |
#15 | TIME LIMIT EXCEEDED | -- | 2 | details |
#16 | TIME LIMIT EXCEEDED | -- | 2 | details |
#17 | ACCEPTED | 0.09 s | 2 | details |
#18 | TIME LIMIT EXCEEDED | -- | 2 | details |
#19 | TIME LIMIT EXCEEDED | -- | 2 | details |
#20 | ACCEPTED | 0.08 s | 2 | details |
#21 | ACCEPTED | 0.10 s | 2 | details |
#22 | TIME LIMIT EXCEEDED | -- | 2 | details |
#23 | TIME LIMIT EXCEEDED | -- | 2 | details |
#24 | TIME LIMIT EXCEEDED | -- | 2 | details |
Code
# import time # import numpy as np _ = input() mappi = [char for char in input()] # start_time = time.time() mappi = [0 if x== "." else x for x in mappi] mappi = [1 if x== "*" else x for x in mappi] mappi[mappi.index("R")] = 2 # mappi = np.array(mappi) askeleet = 0 kolikot = 0 def lähin_kolikkohuone(mappi, robotti_huone_idx): vasen_puoli = mappi[:robotti_huone_idx] vasen_puoli.reverse() # vasen_puoli = np.flipud(vasen_puoli) try: vasen_lähin = vasen_puoli.index(1) # vasen_lähin = np.where(vasen_puoli==1)[0][0] vasen_lähin = len(vasen_puoli) - (vasen_lähin+1) except Exception: vasen_lähin = -1 oikea_puoli = mappi[robotti_huone_idx+1:] try: oikea_lähin = oikea_puoli.index(1) # oikea_lähin = np.where(oikea_puoli==1)[0][0] oikea_lähin += len(mappi[:robotti_huone_idx+1]) except Exception: oikea_lähin = -1 kolikko_idx = -1 vasen_lähin_dist = abs(vasen_lähin-robotti_huone_idx) if vasen_lähin != -1 else 100000 oikea_lähin_dist = abs(oikea_lähin-robotti_huone_idx) if oikea_lähin != -1 else 100000 if vasen_lähin_dist == oikea_lähin_dist: return kolikko_idx elif vasen_lähin_dist < oikea_lähin_dist: kolikko_idx = vasen_lähin else: kolikko_idx = oikea_lähin return kolikko_idx while True: robotti_huone_idx = mappi.index(2) # robotti_huone_idx = np.where(mappi==2)[0][0] kolikko_idx = lähin_kolikkohuone(mappi, robotti_huone_idx) if kolikko_idx == -1: break askeleet += abs(kolikko_idx-robotti_huone_idx) kolikot += 1 mappi[robotti_huone_idx] = 0 mappi[kolikko_idx] = 2 print(askeleet, kolikot) # print(f"--- {(time.time() - start_time)} seconds ---")
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: ACCEPTED
input |
---|
10 **.R...*** |
correct output |
---|
12 5 |
user output |
---|
12 5 |
Test 4
Group: 1, 2
Verdict: ACCEPTED
input |
---|
10 ***R****** |
correct output |
---|
0 0 |
user output |
---|
0 0 |
Test 5
Group: 1, 2
Verdict: ACCEPTED
input |
---|
1000 R................................ |
correct output |
---|
947 9 |
user output |
---|
947 9 |
Test 6
Group: 1, 2
Verdict: ACCEPTED
input |
---|
1000 ................................. |
correct output |
---|
886 9 |
user output |
---|
886 9 |
Test 7
Group: 1, 2
Verdict: ACCEPTED
input |
---|
1000 .....*..*....**..**..*......*.... |
correct output |
---|
1287 400 |
user output |
---|
1287 400 |
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: ACCEPTED
input |
---|
1000 R*****************************... |
correct output |
---|
999 999 |
user output |
---|
999 999 |
Test 11
Group: 1, 2
Verdict: ACCEPTED
input |
---|
1000 ******************************... |
correct output |
---|
999 999 |
user output |
---|
999 999 |
Test 12
Group: 2
Verdict: ACCEPTED
input |
---|
10000 .......**........*...........*... |
correct output |
---|
10971 999 |
user output |
---|
10971 999 |
Test 13
Group: 2
Verdict: ACCEPTED
input |
---|
10000 *..*....*......*.....*..*........ |
correct output |
---|
9999 999 |
user output |
---|
9999 999 |
Test 14
Group: 2
Verdict: ACCEPTED
input |
---|
10000 *.*.*...**.*...*....**.**.**..... |
correct output |
---|
18766 5000 |
user output |
---|
18766 5000 |
Test 15
Group: 2
Verdict: TIME LIMIT EXCEEDED
input |
---|
10000 R*****************************... |
correct output |
---|
9999 9999 |
user output |
---|
(empty) |
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: TIME LIMIT EXCEEDED
input |
---|
200000 ................................. |
correct output |
---|
299934 10000 |
user output |
---|
(empty) |
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: ACCEPTED
input |
---|
200000 R................................ |
correct output |
---|
133765 3 |
user output |
---|
133765 3 |
Test 22
Group: 2
Verdict: TIME LIMIT EXCEEDED
input |
---|
200000 R................................ |
correct output |
---|
199982 5000 |
user output |
---|
(empty) |
Test 23
Group: 2
Verdict: TIME LIMIT EXCEEDED
input |
---|
200000 R*****************************... |
correct output |
---|
199999 199999 |
user output |
---|
(empty) |
Test 24
Group: 2
Verdict: TIME LIMIT EXCEEDED
input |
---|
200000 ******************************... |
correct output |
---|
199999 199999 |
user output |
---|
(empty) |