結果

問題 No.171 スワップ文字列(Med)
コンテスト
ユーザー osa_k
提出日時 2015-03-23 01:30:25
言語 Ruby
(4.0.1)
コンパイル:
ruby -w -c _filename_
実行:
ruby _filename_
結果
AC  
実行時間 55 ms / 1,000 ms
コード長 390 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 155 ms
コンパイル使用メモリ 8,832 KB
実行使用メモリ 15,360 KB
最終ジャッジ日時 2026-03-18 08:23:57
合計ジャッジ時間 1,427 ms
ジャッジサーバーID
(参考情報)
judge1_0 / judge2_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 10
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #
raw source code

# Name: スワップ文字列(Med)
# Level: 3
# Category: 数学

# 任意の隣り合う2つの文字を入れ替えられれば、任意の順列が構成できる。

def fac(n)
    (1..n).reduce(&:*)
end

s = gets.chomp
cnt = s.chars.reduce({}){|h,c| h[c] ||= 0; h[c] += 1; h}.freeze
dups = cnt.values.reduce(1){|a,c| a * fac(c)}
patterns = fac(s.length) / dups
puts (patterns-1) % 573
0