結果

問題 No.256 桁の数字を入れ替え (2)
ユーザー ichibanshiboriichibanshibori
提出日時 2016-10-22 23:49:09
言語 F#
(F# 4.0)
結果
AC  
実行時間 68 ms / 2,000 ms
コード長 518 bytes
コンパイル時間 6,089 ms
コンパイル使用メモリ 193,924 KB
実行使用メモリ 32,476 KB
最終ジャッジ日時 2024-05-02 22:38:41
合計ジャッジ時間 7,105 ms
ジャッジサーバーID
(参考情報)
judge5 / judge4
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 68 ms
30,552 KB
testcase_01 AC 66 ms
30,592 KB
testcase_02 AC 66 ms
32,476 KB
testcase_03 AC 65 ms
32,384 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
  復元対象のプロジェクトを決定しています...
  /home/judge/data/code/main.fsproj を復元しました (199 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 dig_of_char (c:char) = int c - int '0'
let char_of_dig (d:int) = char (d + int '0')

let solve s =
  let sarr = Array.create  10 0 in
  let slen = String.length s in

  let rec make_arr idx =
    if idx < slen then (
      let dig = dig_of_char s.[idx] in
      sarr.[dig] <- sarr.[dig] + 1;
      make_arr (idx + 1)
    )
  in
  make_arr 0;
  seq {9..-1..0} |>
  Seq.map (fun i -> new System.String(char_of_dig i, sarr.[i])) |>
  Seq.fold ( + ) ""

let () =
  let n = stdin.ReadLine() in
  solve n |> printfn "%s"
0