結果

問題 No.858 わり算
ユーザー dsplitdsplit
提出日時 2019-08-12 14:48:17
言語 Haskell
(9.8.2)
結果
AC  
実行時間 3 ms / 2,000 ms
コード長 357 bytes
コンパイル時間 11,057 ms
コンパイル使用メモリ 158,468 KB
実行使用メモリ 7,092 KB
最終ジャッジ日時 2023-10-14 09:58:55
合計ジャッジ時間 11,245 ms
ジャッジサーバーID
(参考情報)
judge14 / judge15
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 3 ms
7,060 KB
testcase_01 AC 3 ms
6,956 KB
testcase_02 AC 3 ms
7,092 KB
testcase_03 AC 3 ms
6,972 KB
testcase_04 AC 2 ms
7,064 KB
testcase_05 AC 2 ms
7,056 KB
testcase_06 AC 3 ms
6,988 KB
testcase_07 AC 3 ms
6,956 KB
testcase_08 AC 3 ms
7,028 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
Loaded package environment from /home/judge/.ghc/x86_64-linux-9.6.1/environments/default
[1 of 2] Compiling Main             ( Main.hs, Main.o )
[2 of 2] Linking a.out

ソースコード

diff #

main :: IO ()
main = interact $ solve . map read . words


-- x は整数部分
-- ys は小数部分をStringにしたもの
solve :: [Int] -> [Char]
solve [a, b] = (show x) ++ "." ++ ys
    where
        (x, y) = divMod a b
        ys = take 50 $ f (10 * y) b

f :: Int -> Int -> String
f n m = show a ++ f (10 * b) m
    where
        (a, b) = divMod n m
0