CSES - Aalto Competitive Programming 2024 - wk3 - Mon - Results
Submission details
Task:Wario kart I
Sender:Mojojijo
Submission time:2024-09-16 17:49:32 +0300
Language:Python3 (PyPy3)
Status:READY
Result:
Test results
testverdicttime
#1ACCEPTED0.04 sdetails
#2ACCEPTED0.04 sdetails
#3ACCEPTED0.04 sdetails
#4ACCEPTED0.04 sdetails
#5ACCEPTED0.04 sdetails
#60.04 sdetails
#70.04 sdetails
#80.04 sdetails
#90.04 sdetails
#100.04 sdetails
#110.04 sdetails
#12ACCEPTED0.04 sdetails
#13ACCEPTED0.04 sdetails
#140.04 sdetails
#15ACCEPTED0.04 sdetails
#160.04 sdetails
#17ACCEPTED0.04 sdetails
#18ACCEPTED0.04 sdetails
#19ACCEPTED0.04 sdetails
#200.04 sdetails
#210.04 sdetails
#220.04 sdetails
#230.04 sdetails
#240.04 sdetails
#25ACCEPTED0.04 sdetails
#260.04 sdetails
#27ACCEPTED0.04 sdetails
#28ACCEPTED0.04 sdetails
#29ACCEPTED0.04 sdetails
#300.04 sdetails
#310.04 sdetails
#320.04 sdetails
#330.04 sdetails
#340.04 sdetails
#35ACCEPTED0.04 sdetails
#360.04 sdetails
#370.04 sdetails
#380.04 sdetails
#390.04 sdetails
#400.04 sdetails
#410.04 sdetails
#420.04 sdetails
#430.04 sdetails
#440.04 sdetails
#450.04 sdetails
#460.04 sdetails
#470.04 sdetails
#480.04 sdetails
#49ACCEPTED0.04 sdetails
#500.04 sdetails
#510.04 sdetails
#520.04 sdetails
#530.04 sdetails
#540.04 sdetails
#550.04 sdetails
#560.04 sdetails
#570.04 sdetails
#580.04 sdetails
#590.04 sdetails
#600.06 sdetails
#610.06 sdetails
#620.06 sdetails
#630.06 sdetails
#640.07 sdetails
#650.05 sdetails
#660.07 sdetails
#670.05 sdetails
#680.07 sdetails
#690.04 sdetails

Code

def maija_position(n, m, k, boost_pads):
    # Convert boost pad positions to meters
    boost_pads = [x * 100 for x in boost_pads]
    track_length = n * 100
    position = 0
    speed = 100
    time_left = k

    for boost in boost_pads:
        if time_left <= 0:
            break
        # Time to reach the boost pad
        time_to_boost = (boost - position) // speed
        if time_to_boost > time_left:
            position += time_left * speed
            time_left = 0
        else:
            position = boost
            time_left -= time_to_boost
            # Apply the boost
            if time_left > 0:
                position += speed * 2
                time_left -= 1

    # Move the remaining time at normal speed
    position += time_left * speed
    position %= track_length  # Wrap around the track

    return position

n,m,k = map(int,(input().split()))

array = list(map(int,input().split()))

print(maija_position(n,m,k,array))

Test details

Test 1

Verdict: ACCEPTED

input
1 0 1 

correct output
0

user output
0

Test 2

Verdict: ACCEPTED

input
1 1 4 

correct output
0

user output
0

Test 3

Verdict: ACCEPTED

input
2 1 9 

correct output
0

user output
0

Test 4

Verdict: ACCEPTED

input
3 0 7 

correct output
100

user output
100

Test 5

Verdict: ACCEPTED

input
3 2 14 
0 2 

correct output
100

user output
100

Test 6

Verdict:

input
3 2 9 
1 2 

correct output
100

user output
200

Test 7

Verdict:

input
4 4 19 
0 1 2 3 

correct output
200

user output
300

Test 8

Verdict:

input
4 1 18 

correct output
0

user output
300

Test 9

Verdict:

input
4 4 9 
0 1 2 3 

correct output
200

user output
100

Test 10

Verdict:

input
5 3 15 
2 3 4 

correct output
400

user output
300

Test 11

Verdict:

input
5 2 25 
3 4 

correct output
100

user output
200

Test 12

Verdict: ACCEPTED

input
5 2 4 
0 4 

correct output
100

user output
100

Test 13

Verdict: ACCEPTED

input
5 3 1 
1 3 4 

correct output
100

user output
100

Test 14

Verdict:

input
5 5 23 
0 1 2 3 4 

correct output
100

user output
300

Test 15

Verdict: ACCEPTED

input
5 1 1 

correct output
100

user output
100

Test 16

Verdict:

input
5 5 24 
0 1 2 3 4 

correct output
300

user output
400

Test 17

Verdict: ACCEPTED

input
5 0 5 

correct output
0

user output
0

Test 18

Verdict: ACCEPTED

input
5 5 0 
0 1 2 3 4 

correct output
0

user output
0

Test 19

Verdict: ACCEPTED

input
5 0 9 

correct output
400

user output
400

Test 20

Verdict:

input
10 6 30 
3 4 5 6 7 8 

correct output
200

user output
600

Test 21

Verdict:

input
10 4 50 
0 1 7 9 

correct output
100

user output
400

Test 22

Verdict:

input
10 4 9 
0 4 5 9 

correct output
200

user output
300

Test 23

Verdict:

input
10 6 3 
1 2 4 5 7 8 

correct output
400

user output
600

Test 24

Verdict:

input
10 10 45 
0 1 2 3 4 5 6 7 8 9 

correct output
0

user output
500

Test 25

Verdict: ACCEPTED

input
10 2 2 
2 8 

correct output
200

user output
200

Test 26

Verdict:

input
10 9 48 
0 1 2 3 4 5 6 8 9 

correct output
600

user output
700

Test 27

Verdict: ACCEPTED

input
10 0 11 

correct output
100

user output
100

Test 28

Verdict: ACCEPTED

input
10 9 0 
0 2 3 4 5 6 7 8 9 

correct output
0

user output
0

Test 29

Verdict: ACCEPTED

input
10 0 18 

correct output
800

user output
800

Test 30

Verdict:

input
100 55 297 
1 2 5 7 8 10 11 13 14 18 21 26...

correct output
6900

user output
5200

Test 31

Verdict:

input
100 42 499 
0 2 3 8 9 12 14 18 19 20 22 23...

correct output
400

user output
4100

Test 32

Verdict:

input
100 44 92 
2 6 7 9 10 11 12 13 15 17 18 2...

correct output
3200

user output
3600

Test 33

Verdict:

input
100 55 35 
1 2 4 5 9 12 14 15 20 21 22 24...

correct output
5400

user output
8200

Test 34

Verdict:

input
100 97 451 
0 1 2 3 4 5 6 7 8 9 10 11 12 1...

correct output
8300

user output
4800

Test 35

Verdict: ACCEPTED

input
100 22 27 
8 18 20 24 29 35 36 39 44 48 5...

correct output
3200

user output
3200

Test 36

Verdict:

input
100 90 474 
0 2 3 4 5 6 8 9 10 11 12 13 14...

correct output
1200

user output
6400

Test 37

Verdict:

input
100 7 113 
30 31 43 45 72 77 97 

correct output
1900

user output
2000

Test 38

Verdict:

input
100 88 5 
0 1 2 3 5 6 7 9 10 11 12 13 14...

correct output
900

user output
2200

Test 39

Verdict:

input
100 1 182 
50 

correct output
8400

user output
8300

Test 40

Verdict:

input
200 110 593 
2 3 4 7 11 12 14 17 19 20 21 2...

correct output
14100

user output
10300

Test 41

Verdict:

input
200 83 998 
0 3 5 6 7 11 14 16 17 18 19 20...

correct output
19600

user output
8100

Test 42

Verdict:

input
200 87 185 
5 13 15 16 19 21 23 25 26 29 3...

correct output
6600

user output
7200

Test 43

Verdict:

input
200 110 70 
3 4 5 8 10 12 13 14 15 17 18 2...

correct output
11000

user output
16100

Test 44

Verdict:

input
200 194 901 
0 1 2 3 4 5 6 7 8 9 10 11 12 1...

correct output
16700

user output
9500

Test 45

Verdict:

input
200 44 55 
2 16 17 18 22 23 31 37 40 41 4...

correct output
6800

user output
7400

Test 46

Verdict:

input
200 179 948 
0 1 2 3 4 5 6 7 8 9 10 11 12 1...

correct output
17200

user output
12700

Test 47

Verdict:

input
200 15 227 
3 14 17 52 53 61 63 83 87 91 1...

correct output
4400

user output
4200

Test 48

Verdict:

input
200 175 11 
0 1 2 4 5 6 7 8 9 10 11 12 13 ...

correct output
2100

user output
7500

Test 49

Verdict: ACCEPTED

input
200 2 364 
99 100 

correct output
16600

user output
16600

Test 50

Verdict:

input
1000 549 2964 
0 4 9 11 12 13 15 16 18 19 20 ...

correct output
60800

user output
51300

Test 51

Verdict:

input
1000 417 4986 
0 2 4 8 9 11 12 13 15 18 19 21...

correct output
6600

user output
40300

Test 52

Verdict:

input
1000 436 925 
0 1 2 4 5 8 9 10 13 16 18 25 2...

correct output
31700

user output
36100

Test 53

Verdict:

input
1000 551 353 
0 2 4 6 9 12 13 18 20 21 22 23...

correct output
54500

user output
78600

Test 54

Verdict:

input
1000 967 4504 
0 1 2 3 4 5 6 7 8 9 10 11 12 1...

correct output
83100

user output
47100

Test 55

Verdict:

input
1000 222 275 
1 2 5 12 14 20 22 24 29 35 51 ...

correct output
33200

user output
34900

Test 56

Verdict:

input
1000 893 4738 
0 2 3 4 5 7 8 10 11 12 13 14 1...

correct output
90500

user output
63100

Test 57

Verdict:

input
1000 76 1136 
15 24 65 72 83 86 100 133 142 ...

correct output
22200

user output
21200

Test 58

Verdict:

input
1000 874 55 
0 1 2 3 4 5 6 7 8 9 10 11 13 1...

correct output
10200

user output
35700

Test 59

Verdict:

input
1000 10 1822 
7 13 133 142 218 316 495 499 5...

correct output
84100

user output
83200

Test 60

Verdict:

input
100000 54882 296454 
0 2 3 4 5 6 7 9 15 16 18 20 21...

correct output
5941200

user output
5133600

Test 61

Verdict:

input
100000 41702 498646 
4 5 6 7 9 11 14 17 18 23 24 29...

correct output
755600

user output
4034800

Test 62

Verdict:

input
100000 43600 92551 
2 4 7 10 12 17 18 30 34 35 36 ...

correct output
3319100

user output
3615100

Test 63

Verdict:

input
100000 55080 35366 
1 2 3 4 6 7 8 12 13 14 15 17 2...

correct output
5465700

user output
7847600

Test 64

Verdict:

input
100000 96704 450359 
0 1 2 3 4 5 6 8 9 10 11 12 13 ...

correct output
8642700

user output
4706300

Test 65

Verdict:

input
100000 22199 27593 
6 14 28 38 39 45 46 48 49 50 5...

correct output
3364900

user output
3534100

Test 66

Verdict:

input
100000 89287 473789 
0 1 2 3 4 5 6 7 8 9 10 12 13 1...

correct output
9652600

user output
6307600

Test 67

Verdict:

input
100000 7630 113681 
0 8 18 24 27 64 69 85 92 102 1...

correct output
2231400

user output
2131100

Test 68

Verdict:

input
100000 87344 5557 
0 1 2 3 4 5 7 8 9 10 11 13 14 ...

correct output
1043700

user output
4459600

Test 69

Verdict:

input
100000 1037 182250 
34 264 299 412 456 495 653 655...

correct output
8414700

user output
8328700