CSES - Datatähti 2025 alku - Results
Submission details
Task:Pizzat
Sender:leonard
Submission time:2024-10-28 14:22:33 +0200
Language:Rust (2021)
Status:READY
Result:100
Feedback
groupverdictscore
#1ACCEPTED100
Test results
testverdicttime
#1ACCEPTED0.00 sdetails
#2ACCEPTED0.00 sdetails
#3ACCEPTED0.00 sdetails
#4ACCEPTED0.00 sdetails
#5ACCEPTED0.00 sdetails
#6ACCEPTED0.01 sdetails
#7ACCEPTED0.00 sdetails
#8ACCEPTED0.00 sdetails
#9ACCEPTED0.00 sdetails
#10ACCEPTED0.00 sdetails
#11ACCEPTED0.00 sdetails
#12ACCEPTED0.00 sdetails
#13ACCEPTED0.00 sdetails

Code

fn main() {
    let mut line: String = "".into();

    std::io::stdin()
        .read_line(&mut line)
        .expect("IO Ongelma :(");

    let numerot: Vec<i32> = line
        .split(' ')
        .map(|x| x.trim().parse::<i32>().expect("Ei numeroita syötteessä."))
        .collect();

    // n m ja k
    assert_eq!(numerot.len(), 3);

    let ihmisiä = numerot[0]; // n
    let pizzoja = numerot[1]; // m
    let mut paloja = numerot[2] * pizzoja; // k * pizzamäärä

    //Likanen helppo soluutio
    let mut v: Vec<i32> = Vec::with_capacity(ihmisiä as usize);

    // Pitäis aina olla turvallinen tho
    unsafe {
        v.set_len(ihmisiä as usize);
    }

    while paloja > 0 {
        for p in v.iter_mut() {
            *p += 1;
            paloja -= 1;

            //Checkaus 2
            if paloja <= 0 {
                break;
            }
        }
    }

    let max = {
        let mut m: i32 = 0;
        for p in v.iter() {
            if *p > m {
                m = *p;
            }
        }
        m
    };

    let min = {
        let mut m: i32 = max;
        for p in v.iter() {
            if *p < m {
                m = *p;
            }
        }
        m
    };

    println!("{} {}", min, max)
}

Test details

Test 1

Verdict: ACCEPTED

input
3 2 4

correct output
2 3

user output
2 3

Test 2

Verdict: ACCEPTED

input
1 1 1

correct output
1 1

user output
1 1

Test 3

Verdict: ACCEPTED

input
1 1 2

correct output
2 2

user output
2 2

Test 4

Verdict: ACCEPTED

input
2 1 1

correct output
0 1

user output
0 1

Test 5

Verdict: ACCEPTED

input
2 5 7

correct output
17 18

user output
17 18

Test 6

Verdict: ACCEPTED

input
1 1000 1000

correct output
1000000 1000000

user output
1000000 1000000

Test 7

Verdict: ACCEPTED

input
1000 1000 1000

correct output
1000 1000

user output
1000 1000

Test 8

Verdict: ACCEPTED

input
1000 1 1

correct output
0 1

user output
0 1

Test 9

Verdict: ACCEPTED

input
997 995 997

correct output
995 995

user output
995 995

Test 10

Verdict: ACCEPTED

input
997 994 997

correct output
994 994

user output
994 994

Test 11

Verdict: ACCEPTED

input
997 996 995

correct output
994 995

user output
994 995

Test 12

Verdict: ACCEPTED

input
997 996 996

correct output
995 996

user output
995 996

Test 13

Verdict: ACCEPTED

input
997 995 499

correct output
497 498

user output
497 498