結果

問題 No.500 階乗電卓
ユーザー Nobita Gomu
提出日時 2017-09-26 22:01:51
言語 F#
(F# 4.0)
結果
RE  
実行時間 -
コード長 402 bytes
コンパイル時間 8,398 ms
コンパイル使用メモリ 187,608 KB
実行使用メモリ 37,760 KB
最終ジャッジ日時 2024-11-15 16:53:54
合計ジャッジ時間 13,849 ms
ジャッジサーバーID
(参考情報)
judge3 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 12 RE * 8
権限があれば一括ダウンロードができます
コンパイルメッセージ
  復元対象のプロジェクトを決定しています...
  /home/judge/data/code/main.fsproj を復元しました (258 ms)。
MSBuild のバージョン 17.9.6+a4ecab324 (.NET)
  main -> /home/judge/data/code/bin/Release/net8.0/main.dll
  main -> /home/judge/data/code/bin/Release/net8.0/publish/

ソースコード

diff #

let factorial n =
    if n >= 50 then
        bigint.Zero
    else
        seq { 1..n } |> Seq.map bigint |> Seq.reduce (*)

let fmt (n:bigint) =
    if n = bigint.Zero then
        "000000000000"
    else
        let s = string n
        match String.length s with
        | i when i > 12 -> s.[i-12..i-1]
        | _ -> s

let calc = int >> factorial >> fmt

stdin.ReadLine () |> calc |> printfn "%s"
0