CSES - Aalto Competitive Programming 2024 - wk3 - Mon - Results
Submission details
Task:Wario kart I
Sender:odanobunaga8199
Submission time:2024-09-16 16:39:15 +0300
Language:C++ (C++20)
Status:READY
Result:
Test results
testverdicttime
#1ACCEPTED0.00 sdetails
#2ACCEPTED0.00 sdetails
#3ACCEPTED0.00 sdetails
#4ACCEPTED0.00 sdetails
#50.00 sdetails
#6ACCEPTED0.00 sdetails
#70.00 sdetails
#80.00 sdetails
#90.00 sdetails
#10ACCEPTED0.00 sdetails
#11ACCEPTED0.00 sdetails
#120.00 sdetails
#13ACCEPTED0.00 sdetails
#140.00 sdetails
#15ACCEPTED0.00 sdetails
#160.00 sdetails
#17ACCEPTED0.00 sdetails
#18ACCEPTED0.00 sdetails
#19ACCEPTED0.00 sdetails
#200.00 sdetails
#210.00 sdetails
#220.00 sdetails
#23ACCEPTED0.00 sdetails
#240.00 sdetails
#25ACCEPTED0.00 sdetails
#260.00 sdetails
#27ACCEPTED0.00 sdetails
#28ACCEPTED0.00 sdetails
#29ACCEPTED0.00 sdetails
#300.00 sdetails
#310.00 sdetails
#320.00 sdetails
#330.00 sdetails
#340.00 sdetails
#350.00 sdetails
#360.00 sdetails
#370.00 sdetails
#380.00 sdetails
#39ACCEPTED0.00 sdetails
#400.00 sdetails
#410.00 sdetails
#420.00 sdetails
#430.00 sdetails
#440.00 sdetails
#450.00 sdetails
#460.00 sdetails
#470.00 sdetails
#480.00 sdetails
#49ACCEPTED0.00 sdetails
#500.00 sdetails
#510.00 sdetails
#520.00 sdetails
#530.00 sdetails
#540.00 sdetails
#550.00 sdetails
#560.00 sdetails
#570.00 sdetails
#580.00 sdetails
#590.00 sdetails
#600.04 sdetails
#610.05 sdetails
#620.02 sdetails
#630.01 sdetails
#640.05 sdetails
#650.01 sdetails
#660.05 sdetails
#670.01 sdetails
#680.01 sdetails
#690.01 sdetails

Code

#include <bits/stdc++.h>
using namespace std;


int main(){
    ios::sync_with_stdio(false);
    cin.tie(0);
    
    int n, m, k;
    cin >> n >> m >> k;
    
    vector<int> a(m);
    for(auto &x: a){
        cin >> x;
        x *= 100; // Convert to meters
    }
    
    sort(a.begin(), a.end());
    
    int track_length = n * 100;
    int current_pos = 0;
    bool boost_active = false;
    bool next_boost = false;
    
    for(int i = 0; i < k; ++i){
        int speed = boost_active ? 200 : 100;
        int new_pos = (current_pos + speed) % track_length;
        if(!boost_active && m > 0){
            bool has_boost = false;
            if(current_pos < new_pos){
                int l = current_pos + 1;
                int r = new_pos;
                int l_idx = lower_bound(a.begin(), a.end(), l) - a.begin();
                int r_idx = upper_bound(a.begin(), a.end(), r) - a.begin();
                if(l_idx < r_idx){
                    has_boost = true;
                }
            }
            else{
                int l1 = current_pos + 1;
                int r1 = track_length - 1;
                if(l1 <= r1){
                    int l_idx1 = lower_bound(a.begin(), a.end(), l1) - a.begin();
                    int r_idx1 = upper_bound(a.begin(), a.end(), r1) - a.begin();
                    if(l_idx1 < r_idx1){
                        has_boost = true;
                    }
                }
                if(!has_boost && new_pos >= 0){
                    int l2 = 0;
                    int r2 = new_pos;
                    if(l2 <= r2){
                        int l_idx2 = lower_bound(a.begin(), a.end(), l2) - a.begin();
                        int r_idx2 = upper_bound(a.begin(), a.end(), r2) - a.begin();
                        if(l_idx2 < r_idx2){
                            has_boost = true;
                        }
                    }
                }
            }
            next_boost = has_boost;
        }
        else{
            next_boost = false;
        }
        current_pos = new_pos;
        boost_active = next_boost;
    }
    
    cout << current_pos;
}

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:

input
3 2 14 
0 2 

correct output
100

user output
200

Test 6

Verdict: ACCEPTED

input
3 2 9 
1 2 

correct output
100

user output
100

Test 7

Verdict:

input
4 4 19 
0 1 2 3 

correct output
200

user output
0

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: ACCEPTED

input
5 3 15 
2 3 4 

correct output
400

user output
400

Test 11

Verdict: ACCEPTED

input
5 2 25 
3 4 

correct output
100

user output
100

Test 12

Verdict:

input
5 2 4 
0 4 

correct output
100

user output
400

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
400

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
100

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
800

Test 21

Verdict:

input
10 4 50 
0 1 7 9 

correct output
100

user output
300

Test 22

Verdict:

input
10 4 9 
0 4 5 9 

correct output
200

user output
100

Test 23

Verdict: ACCEPTED

input
10 6 3 
1 2 4 5 7 8 

correct output
400

user output
400

Test 24

Verdict:

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

correct output
0

user output
700

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
800

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
700

Test 31

Verdict:

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

correct output
400

user output
3800

Test 32

Verdict:

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

correct output
3200

user output
2200

Test 33

Verdict:

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

correct output
5400

user output
4800

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
7300

Test 35

Verdict:

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

correct output
3200

user output
3100

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
600

Test 37

Verdict:

input
100 7 113 
30 31 43 45 72 77 97 

correct output
1900

user output
1800

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
700

Test 39

Verdict: ACCEPTED

input
100 1 182 
50 

correct output
8400

user output
8400

Test 40

Verdict:

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

correct output
14100

user output
100

Test 41

Verdict:

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

correct output
19600

user output
9800

Test 42

Verdict:

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

correct output
6600

user output
4300

Test 43

Verdict:

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

correct output
11000

user output
9600

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
14500

Test 45

Verdict:

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

correct output
6800

user output
6500

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
19400

Test 47

Verdict:

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

correct output
4400

user output
4300

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
1600

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
99400

Test 51

Verdict:

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

correct output
6600

user output
45800

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
19400

Test 53

Verdict:

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

correct output
54500

user output
47500

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
72300

Test 55

Verdict:

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

correct output
33200

user output
31800

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
96900

Test 57

Verdict:

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

correct output
22200

user output
21800

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
8000

Test 59

Verdict:

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

correct output
84100

user output
83900

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
109100

Test 61

Verdict:

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

correct output
755600

user output
4588500

Test 62

Verdict:

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

correct output
3319100

user output
2068900

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
4787000

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
7187400

Test 65

Verdict:

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

correct output
3364900

user output
3255000

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
9736900

Test 67

Verdict:

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

correct output
2231400

user output
2173900

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
815700

Test 69

Verdict:

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

correct output
8414700

user output
8413200