CSES - Datatähti 2025 alku - Results
Submission details
Task:Kortit I
Sender:Japivee
Submission time:2024-10-29 13:58:53 +0200
Language:Node.js
Status:READY
Result:0
Feedback
groupverdictscore
#10
#20
#30
Test results
testverdicttimegroup
#10.12 s1, 2, 3details
#20.12 s2, 3details
#30.12 s3details
#40.12 s3details
#50.12 s3details
#60.12 s3details
#70.12 s3details
#80.12 s3details
#90.12 s3details
#100.12 s3details
#110.12 s3details
#120.13 s3details
#130.13 s3details
#140.12 s3details
#150.12 s3details
#160.12 s3details
#170.12 s3details
#180.13 s3details
#190.13 s3details
#200.12 s3details

Code

let rows = -1;
let tasks = [];
function kortit(input){
    if (rows == -1) {
        rows = Number(input) - 1;
    } else {
        if (rows !== 0) {
        tasks.push(input.split(" "));
        rows--;
        } else {
            tasks.push(input.split(" "));
            console.log(run(tasks));
        }
    }
}
function run(tasks){
    let answer = "";
    let numbers = "1";
    for (let i = 2;i < 101;i++) {
        numbers += " " + i;
    }
    tasks.forEach(function(task){
        let ab = Number(task[1]) + Number(task[2]);
        let a = task[1];
        let b = task[2];
        let n = task[0];
        if (n < (a + b)) {
            answer += "NO\n";
            return;
        }
        if (a == 0 || b == 0) {
            if (a == 0 && b == 0) {
                let temp = numbers.slice(0, n*2 - 1) + "\n";
                answer += "YES\n" + temp + temp;
                return;
            } else {
                answer += "NO\n";
                return;
            }
        }
        let row1 = "";
        let row2 = "";
        
        if (b>a) {
            row2 += numbers.slice(0, n*2);
            row1 += numbers.slice(0, (n - ab)*2);
            row1 += numbers.slice((n - a)*2 - 1, n*2 - 1).split(" ").reverse().join(" ");
            row1 += numbers.slice((n - ab)*2, (n - a)*2);
        } else {
            row1 += numbers.slice(0, n*2);
            row2 += numbers.slice(0, (n - ab)*2);
            row2 += numbers.slice((n - b)*2 - 1, n*2 - 1).split(" ").reverse().join(" ");
            row2 += numbers.slice((n - ab)*2, (n - b)*2);
        }
        answer += "YES\n" + row1 + "\n" + row2 + "\n";
    });
    return answer;
}
//n on korttien maksimiarvo, sekä vuorojen määrä.
//4 3 2 1   3 1--> max n-1
//3 2 1 4

//1 2 3 4  1 2
//1 4 3 2

//4 3 2 1  1 1  
//1 3 2 4

//4 3 2 1  2 2
//1 2 3 4

//1 6 5 4 3 2  2 3
//1 4 3 2 5 6

//1 2 3 4 5 6
//1 6 5 2 3 4

//säännöt: a + b !> n, | a = 0, b != 0 | 
local = false;
const readline = require('readline');
const rl = readline.createInterface({
    input: process.stdin,
    output: process.stdout,
    terminal:false
});
function with_time(timing){
    rl.on(`line`, number => {
        timing(kortit, [number]);
    });
}
function without_time(){
    rl.on(`line`, number => {
        kortit(number);
    });
}
if (local) {
    const timing = require('./timing.js');
    with_time(timing);
} else {
    without_time();
} 

Test details

Test 1

Group: 1, 2, 3

Verdict:

input
54
4 4 0
3 1 3
3 2 2
4 0 4
...

correct output
NO
NO
NO
NO
NO
...

user output
NO
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

Test 2

Group: 2, 3

Verdict:

input
284
6 1 0
5 0 2
7 1 5
7 7 5
...

correct output
NO
NO
YES
1 2 3 4 5 6 7 
2 3 4 5 6 1 7 
...

user output
NO
NO
YES
1 7 2 3 4 5 6 
1 2 3 4 5 6 7 
...

Test 3

Group: 3

Verdict:

input
955
14 2 10
12 2 5
10 4 9
14 1 13
...

correct output
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

user output
NO
NO
NO
YES
 21 2 3 4 5 6 7 8 9 10 11 12
...

Test 4

Group: 3

Verdict:

input
869
17 12 9
16 8 4
15 9 9
17 11 15
...

correct output
NO
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

user output
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

Test 5

Group: 3

Verdict:

input
761
18 3 15
19 1 15
18 8 1
19 19 17
...

correct output
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

user output
NO
YES
1 2 3 1 4 5 6 7 8 9 10 11 12 1...

Test 6

Group: 3

Verdict:

input
925
21 14 21
20 18 18
20 7 6
21 14 9
...

correct output
NO
NO
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

user output
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

Test 7

Group: 3

Verdict:

input
529
22 3 3
22 17 5
22 6 15
22 22 20
...

correct output
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

user output
NO
YES
1 17 16 15 14 13 12 11 10 9 8 ...

Test 8

Group: 3

Verdict:

input
576
23 18 9
23 16 8
23 16 13
23 16 22
...

correct output
NO
NO
NO
NO
NO
...

user output
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

Test 9

Group: 3

Verdict:

input
625
24 2 22
24 15 21
24 6 3
24 21 1
...

correct output
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

user output
YES
19 81 2 3 4 5 6 7 8 9 10 11 12...

Test 10

Group: 3

Verdict:

input
676
25 16 25
25 15 2
25 15 7
25 15 16
...

correct output
NO
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

user output
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

Test 11

Group: 3

Verdict:

input
729
26 2 18
26 14 18
26 5 18
26 19 13
...

correct output
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

user output
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

Test 12

Group: 3

Verdict:

input
784
27 26 7
27 14 0
27 14 5
27 14 14
...

correct output
NO
NO
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

user output
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

Test 13

Group: 3

Verdict:

input
841
28 26 16
28 13 19
28 5 8
28 26 4
...

correct output
NO
NO
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

user output
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

Test 14

Group: 3

Verdict:

input
900
29 24 15
29 13 2
29 13 7
29 13 16
...

correct output
NO
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

user output
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

Test 15

Group: 3

Verdict:

input
961
30 24 26
30 12 24
30 4 29
30 24 14
...

correct output
NO
NO
NO
NO
YES
...

user output
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

Test 16

Group: 3

Verdict:

input
1000
15 12 6
33 18 30
44 4 26
6 6 5
...

correct output
NO
NO
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

user output
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

Test 17

Group: 3

Verdict:

input
1000
45 32 30
4 0 3
46 23 10
71 19 46
...

correct output
NO
NO
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

user output
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

Test 18

Group: 3

Verdict:

input
1000
51 29 37
75 11 72
5 2 4
31 8 26
...

correct output
NO
NO
NO
NO
YES
...

user output
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

Test 19

Group: 3

Verdict:

input
1000
50 20 37
99 45 58
86 79 73
85 70 54
...

correct output
NO
NO
NO
NO
NO
...

user output
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...

Test 20

Group: 3

Verdict:

input
1000
26 23 5
73 53 59
64 47 41
80 75 55
...

correct output
NO
NO
NO
NO
NO
...

user output
YES
1 2 3 4 5 6 7 8 9 10 11 12 13 ...