結果
| 問題 | No.170 スワップ文字列(Easy) |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2026-05-03 00:27:23 |
| 言語 | Standard ML (MLton 20241230) |
| 結果 |
AC
|
| 実行時間 | 1 ms / 5,000 ms |
| コード長 | 1,310 bytes |
| 記録 | |
| コンパイル時間 | 3,604 ms |
| コンパイル使用メモリ | 704,740 KB |
| 実行使用メモリ | 6,400 KB |
| 最終ジャッジ日時 | 2026-05-03 00:27:33 |
| 合計ジャッジ時間 | 5,767 ms |
|
ジャッジサーバーID (参考情報) |
judge1_0 / judge2_0 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 21 |
ソースコード
fun readStr () =
let
fun scan reader stream = SOME (StringCvt.splitl (not o Char.isSpace) reader (StringCvt.skipWS reader stream))
in
valOf (TextIO.scanStream scan TextIO.stdIn)
end
fun fact 0 = 1
| fact 1 = 1
| fact n =
n * fact (n - 1)
val () =
let
val s = readStr ()
val table = List.foldl (fn (ch, array) =>
let
val index = Char.ord ch - Char.ord #"A"
val oldValue = Array.sub (array, index)
val newValue = oldValue + 1
in
(
Array.update (array, index, newValue);
array
)
end)
(Array.array (26, 0))
(String.explode s)
val ans = (Array.foldl (fn (n, acc) =>
acc div (fact n))
(fact (String.size s))
table) - 1
in
print (Int.toString ans ^ "\n")
end