結果

問題 No.78 クジ付きアイスバー
ユーザー ciel
提出日時 2014-11-26 00:07:41
言語 Ruby
(3.4.1)
結果
AC  
実行時間 86 ms / 5,000 ms
コード長 367 bytes
コンパイル時間 65 ms
コンパイル使用メモリ 7,424 KB
実行使用メモリ 12,288 KB
最終ジャッジ日時 2024-11-07 23:50:46
合計ジャッジ時間 4,312 ms
ジャッジサーバーID
(参考情報)
judge5 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other AC * 35
権限があれば一括ダウンロードができます
コンパイルメッセージ
ruby: warning: shebang line ending with \r may cause problems
Syntax OK

ソースコード

diff #

#!/usr/bin/ruby
N,K=gets.split.map(&:to_i)
S=gets.chomp.chars.map(&:to_i)

#phase1: brute force
buy=[0]*(N+1)
atari=0
1.step(N){|i|
	if atari==0
		atari+=1
		buy[i]=1
	end
	buy[i]+=buy[i-1]
	atari+=S[i-1]-1
}

d,r=(K-1).divmod(N)
r+=1
if d==0
	p buy[r]
else
	#phase2: use multiply
	p buy[-1]+(d-1)*[buy[-1]-atari,0].max+[buy[r]-atari,0].max
end
0