結果

問題 No.294 SuperFizzBuzz
ユーザー code-devo
提出日時 2016-03-05 13:19:51
言語 Ruby
(3.4.1)
結果
AC  
実行時間 110 ms / 5,000 ms
コード長 1,434 bytes
コンパイル時間 173 ms
コンパイル使用メモリ 7,552 KB
実行使用メモリ 12,288 KB
最終ジャッジ日時 2024-12-26 06:03:02
合計ジャッジ時間 2,498 ms
ジャッジサーバーID
(参考情報)
judge4 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 12
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #
プレゼンテーションモードにする

def combination(n, r)
r = n - r if n - r < r
return 1 if r == 0
num = n.downto(n-r+1).inject(&:*)
den = r.downto(1).inject(&:*)
return num / den
end
K = 25
TBL1 = Hash.new{0} #KSuperFizzBuzz
TBL2 = {} #K355
for five in 1..K do
for three in 0..(K-five) do
count = combination(three + five - 1, five - 1) #151
TBL1[three + five] += count if five % 3 == 0
TBL2[[three, five]] = count
end
end
n = gets.to_i
#nSuperFizzBuzz
#keta:
#no:
keta = 1
sum = 0
loop do
count = TBL1[keta]
break if sum + count >= n #nnSuperFizzBuzzketa
sum += count
keta += 1
end
no = n - sum
#"3""5"
three = 0 #"3"
five = 0 #"5"
sum = 0
ans = []
(keta).downto(1) do |k|
count = 0 #k"3"SuperFizzBuzz
(3 - five % 3).step(k - 1, 3) do |f|
t = k - f - 1
count += TBL2[[t, f]]
end
if sum + count < no then
ans << "5"
five += 1
sum += count
else
ans << "3"
three += 1
end
end
puts ans.join
הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
0