結果

問題 No.256 桁の数字を入れ替え (2)
ユーザー ichibanshibori
提出日時 2016-10-22 23:49:09
言語 F#
(F# 4.0)
結果
AC  
実行時間 77 ms / 2,000 ms
コード長 518 bytes
コンパイル時間 13,052 ms
コンパイル使用メモリ 184,864 KB
実行使用メモリ 32,512 KB
最終ジャッジ日時 2024-11-23 17:46:56
合計ジャッジ時間 10,710 ms
ジャッジサーバーID
(参考情報)
judge3 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 4
権限があれば一括ダウンロードができます
コンパイルメッセージ
  復元対象のプロジェクトを決定しています...
  /home/judge/data/code/main.fsproj を復元しました (412 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