結果
問題 |
No.846 メダル
|
ユーザー |
|
提出日時 | 2020-02-02 22:12:34 |
言語 | Rust (1.83.0 + proconio) |
結果 |
AC
|
実行時間 | 1 ms / 2,000 ms |
コード長 | 943 bytes |
コンパイル時間 | 13,438 ms |
コンパイル使用メモリ | 384,808 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-09-18 21:28:43 |
合計ジャッジ時間 | 14,360 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 22 |
ソースコード
use std::io::Read; use std::cmp::{max, min}; fn main() { let mut all_data = String::new(); std::io::stdin().read_to_string(&mut all_data).ok(); let all_data: Vec<&str> = all_data.trim().split('\n').map(|s| s.trim()).collect(); let pqr: Vec<usize> = all_data.iter().next().unwrap().split_whitespace().map(|s| s.parse().unwrap()).collect(); let abc: Vec<usize> = all_data.iter().skip(1).next().unwrap().split_whitespace().map(|s| s.parse().unwrap()).collect(); let mut max_val = pqr[0] * abc[0]; let mut min_val = pqr[0] * (abc[0] - 1) + 1; max_val = min(max_val, pqr[1] * (abc[1] + abc[0])); min_val = max(min_val, pqr[1] * (abc[1] + abc[0] - 1) + 1); max_val = min(max_val, pqr[2] * (abc[2] + abc[1] + abc[0])); min_val = max(min_val, pqr[2] * (abc[2] + abc[1] + abc[0] - 1) + 1); if min_val <= max_val { println!("{} {}", min_val, max_val); } else { println!("-1"); } }