結果

問題 No.156 キャンディー・ボックス
ユーザー m0ntBL4Nc
提出日時 2019-10-10 13:40:24
言語 Rust
(1.37.0)
結果
AC  
実行時間 108 ms
コード長 1,358 Byte
コンパイル時間 735 ms
使用メモリ 964 KB
最終ジャッジ日時 2019-10-10 13:40:26

テストケース

テストケース表示
入力 結果 実行時間
使用メモリ
99_system_test1.txt AC 3 ms
964 KB
challenge01.txt AC 2 ms
956 KB
sample1.txt AC 1 ms
960 KB
sample2.txt AC 2 ms
956 KB
sample3.txt AC 1 ms
960 KB
sample4.txt AC 5 ms
964 KB
system_test1.txt AC 8 ms
964 KB
system_test2.txt AC 7 ms
964 KB
system_test3.txt AC 6 ms
960 KB
system_test4.txt AC 5 ms
964 KB
system_test5.txt AC 6 ms
956 KB
system_test6.txt AC 4 ms
960 KB
system_test7.txt AC 7 ms
964 KB
system_test8.txt AC 6 ms
960 KB
system_test9.txt AC 5 ms
960 KB
system_test10.txt AC 6 ms
956 KB
system_test11.txt AC 4 ms
960 KB
system_test12.txt AC 8 ms
960 KB
system_test13.txt AC 4 ms
960 KB
system_test14.txt AC 4 ms
960 KB
system_test15.txt AC 2 ms
960 KB
system_test16.txt AC 5 ms
956 KB
system_test17.txt AC 4 ms
956 KB
system_test18.txt AC 2 ms
956 KB
test1.txt AC 3 ms
960 KB
test2.txt AC 3 ms
960 KB
test3.txt AC 2 ms
964 KB
test4.txt AC 2 ms
960 KB
test5.txt AC 2 ms
956 KB
test6.txt AC 2 ms
956 KB
test7.txt AC 15 ms
956 KB
test8.txt AC 7 ms
960 KB
test9.txt AC 107 ms
956 KB
test10.txt AC 108 ms
956 KB
テストケース一括ダウンロード

ソースコード

diff #
fn getline() -> String {
    let mut __ret = String::new();
    std::io::stdin().read_line(&mut __ret).ok();
    return __ret;
}

fn main() {
    let mut number_of_empty_candy_box = 0;

    let line = getline();
    let params: Vec<_> = line.trim().split(' ').collect();
    let number_of_candy_box: usize = params[0].parse().unwrap();
    let number_of_pick_candy: usize = params[1].parse().unwrap();

    let line = getline();
    let params: Vec<_> = line.trim().split(' ').collect();
    let mut candy_boxes: Vec<i32> = Vec::new();

    for i in 0..number_of_candy_box {
        let number_of_candy: i32 = params[i].parse().unwrap();
        candy_boxes.push(number_of_candy);
    }


    for _ in 0..number_of_pick_candy {
        let mut min = 1000000;
        let mut min_candy_box_index: usize = 0;

        for i in 0..number_of_candy_box {
            if candy_boxes[i] == 0 {
                continue;
            }
            if candy_boxes[i] <= min {
                min = candy_boxes[i];
                min_candy_box_index = i;
            }
        }

        if candy_boxes[min_candy_box_index] - 1 >= 0 {
            candy_boxes[min_candy_box_index] -= 1;
            if candy_boxes[min_candy_box_index] == 0 {
                number_of_empty_candy_box += 1;
            }
        }
    }

    println!("{}", number_of_empty_candy_box);
}
0