結果

問題 No.143 豆
コンテスト
ユーザー _yoshih_
提出日時 2018-09-19 23:15:25
言語 Rust
(1.94.0 + proconio + num + itertools)
コンパイル:
/usr/bin/rustc_custom
実行:
./target/release/main
結果
AC  
実行時間 1 ms / 1,000 ms
コード長 659 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 3,314 ms
コンパイル使用メモリ 187,656 KB
実行使用メモリ 7,976 KB
最終ジャッジ日時 2026-04-03 14:00:24
合計ジャッジ時間 4,564 ms
ジャッジサーバーID
(参考情報)
judge3_0 / judge4_1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 17
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

use std::io::*;
use std::str::*;

fn read<T: FromStr>(sl: &mut StdinLock) -> Option<T> {
    let s = sl.by_ref().bytes().map(|c| c.unwrap() as char)
        .skip_while(|c| c.is_whitespace())
        .take_while(|c| !c.is_whitespace())
        .collect::<String>();

    s.parse::<T>().ok()
}

fn run(sl: &mut StdinLock) {
    let k = read::<i32>(sl).unwrap();
    let n = read::<i32>(sl).unwrap();
    let f = read::<i32>(sl).unwrap();

    let sum = (0..f).map(|_| read::<i32>(sl).unwrap()).sum();
    let r = if k*n >= sum { k*n - sum } else { -1 };
    println!("{}", r);
}

fn main() {
    let s = stdin();
    let mut sl = s.lock();
    run(&mut sl);
}
0