結果
問題 |
No.988 N×Mマス計算(総和)
|
ユーザー |
|
提出日時 | 2021-02-04 02:16:34 |
言語 | Rust (1.83.0 + proconio) |
結果 |
AC
|
実行時間 | 30 ms / 2,000 ms |
コード長 | 1,626 bytes |
コンパイル時間 | 18,847 ms |
コンパイル使用メモリ | 379,472 KB |
実行使用メモリ | 8,320 KB |
最終ジャッジ日時 | 2024-06-30 09:14:36 |
合計ジャッジ時間 | 13,175 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 19 |
ソースコード
fn main() { let (n, m, k) = get_nmk(); let (operator, row) = get_row(k); let column = get_column(n, k); let ans = get_ans(operator, row, column, n, m, k); println!("{}", ans); } fn add(row: i64, column: i64, n: i64, m: i64, k: i64) -> i64 { (row * n + column * m) % k } fn mul(row: i64, column: i64, k: i64) -> i64 { row * column % k } fn get_ans(op: Operator, row: i64, column: i64, n: i64, m: i64, k: i64) -> i64 { match op { Operator::Add => add(row, column, n, m, k), Operator::Mul => mul(row, column, k), } } fn get_column(n: i64, k: i64) -> i64 { (0..n) .map(|_| { read_line() .into_iter() .next() .unwrap() .parse::<i64>() .unwrap() }) .sum::<i64>() % k } fn get_row(k: i64) -> (Operator, i64) { let mut iter = read_line().into_iter(); let op = match iter.next().unwrap() { a if a == "+" => Operator::Add, _ => Operator::Mul, }; ( op, iter.map(|num| num.parse::<i64>().unwrap()).sum::<i64>() % k, ) } enum Operator { Add, Mul, } fn get_nmk() -> (i64, i64, i64) { let mut iter = read_line().into_iter(); ( iter.next().unwrap().parse().unwrap(), iter.next().unwrap().parse().unwrap(), iter.next().unwrap().parse().unwrap(), ) } fn read_line() -> Vec<String> { let mut line = String::new(); std::io::stdin().read_line(&mut line).unwrap(); line.split_whitespace() .map(|e| e.to_string()) .collect::<Vec<_>>() }