結果
問題 | No.858 わり算 |
ユーザー | iwot |
提出日時 | 2019-08-13 13:47:19 |
言語 | Rust (1.83.0 + proconio) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,143 bytes |
コンパイル時間 | 11,881 ms |
コンパイル使用メモリ | 400,788 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-09-19 13:24:38 |
合計ジャッジ時間 | 12,402 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 1 ms
5,248 KB |
testcase_01 | AC | 1 ms
5,376 KB |
testcase_02 | AC | 1 ms
5,376 KB |
testcase_03 | AC | 1 ms
5,376 KB |
testcase_04 | AC | 1 ms
5,376 KB |
testcase_05 | AC | 1 ms
5,376 KB |
testcase_06 | WA | - |
testcase_07 | AC | 1 ms
5,376 KB |
testcase_08 | AC | 1 ms
5,376 KB |
ソースコード
fn read_vec<T: std::str::FromStr>() -> Vec<T> { let mut s = String::new(); std::io::stdin().read_line(&mut s).ok(); s.trim() .split_whitespace() .map(|e| e.parse().ok().unwrap()) .collect() } fn div(ans: &mut Vec<char>, left: u32, divn: u32, countdown: u32) { let top = left / divn; let rest = left % divn; if top < 10 { ans.push(std::char::from_digit(top, 10).unwrap()); } else { for c in top.to_string().chars() { ans.push(c); } } if countdown == 0 { if ans.len() < 51 { for _ in ans.len()..51 { ans.push('0'); } } return; } if rest > 0 { div(ans, rest * 10, divn, countdown - 1); } else { if ans.len() < 51 { for _ in ans.len()..51 { ans.push('0'); } } } } fn main() { let input: Vec<u32> = read_vec(); let mut ans = vec![]; div(&mut ans, input[0], input[1], 50); ans.insert(ans.len() - 50, '.'); let result: String = ans.into_iter().collect(); println!("{}", result); }