結果

問題 No.858 わり算
ユーザー iwotiwot
提出日時 2019-08-13 14:13:27
言語 Rust
(1.77.0 + proconio)
結果
AC  
実行時間 1 ms / 2,000 ms
コード長 1,340 bytes
コンパイル時間 11,684 ms
コンパイル使用メモリ 403,132 KB
実行使用メモリ 5,376 KB
最終ジャッジ日時 2024-09-19 13:25:54
合計ジャッジ時間 12,464 ms
ジャッジサーバーID
(参考情報)
judge5 / judge1
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
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 0 ms
5,376 KB
testcase_04 AC 1 ms
5,376 KB
testcase_05 AC 1 ms
5,376 KB
testcase_06 AC 1 ms
5,376 KB
testcase_07 AC 1 ms
5,376 KB
testcase_08 AC 1 ms
5,376 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

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()
}

struct Num {
    top: Option<String>,
    nums: Vec<char>,
}

impl Num {
    pub fn to_string(self) -> String {
        let tail: String = self.nums.into_iter().collect();
        self.top.unwrap() + "." + tail.as_ref()
    }
}

fn div(ans: &mut Num, left: u32, divn: u32, countdown: u32) {
    let top = left / divn;
    let rest = left % divn;
    if ans.top.is_none() {
        ans.top = Some(top.to_string());
    } else {
        ans.nums.push(std::char::from_digit(top, 10).unwrap());
    }
    if countdown == 0 {
        if ans.nums.len() < 50 {
            for _ in ans.nums.len()..50 {
                ans.nums.push('0');
            }
        }
        return;
    }
    if rest > 0 {
        div(ans, rest * 10, divn, countdown - 1);
    } else {
        if ans.nums.len() < 50 {
            for _ in ans.nums.len()..50 {
                ans.nums.push('0');
            }
        }
    }
}

fn main() {
    let input: Vec<u32> = read_vec();

    let mut ans = Num {top: None, nums: vec![]};
    div(&mut ans, input[0], input[1], 50);
    let result = ans.to_string();

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