結果

問題 No.500 階乗電卓
コンテスト
ユーザー Nobita Gomu
提出日時 2017-09-26 22:12:15
言語 F#
(F# 10.0)
コンパイル:
fsharp_c _filename_
実行:
/usr/bin/dotnet_wrap
結果
AC  
実行時間 53 ms / 2,000 ms
コード長 503 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 12,574 ms
コンパイル使用メモリ 199,964 KB
実行使用メモリ 34,432 KB
最終ジャッジ日時 2026-03-11 07:37:17
合計ジャッジ時間 8,659 ms
ジャッジサーバーID
(参考情報)
judge2_0 / judge1_1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 20
権限があれば一括ダウンロードができます
コンパイルメッセージ
  復元対象のプロジェクトを決定しています...
  /home/judge/data/code/main.fsproj を復元しました (177 ミリ秒)。
  main -> /home/judge/data/code/bin/Release/net10.0/main.dll
  main -> /home/judge/data/code/bin/Release/net10.0/publish/

ソースコード

diff #
raw source code

let reader (s:string) =
    match String.length s with
    | i when i > 2 -> 50
    | _ -> int s

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 = reader >> factorial >> fmt

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