結果
| 問題 | No.3 ビットすごろく |
| コンテスト | |
| ユーザー |
zazaboon
|
| 提出日時 | 2017-02-26 23:54:14 |
| 言語 | Ruby (3.4.1) |
| 結果 |
AC
|
| 実行時間 | 157 ms / 5,000 ms |
| コード長 | 904 bytes |
| コンパイル時間 | 52 ms |
| コンパイル使用メモリ | 7,424 KB |
| 実行使用メモリ | 12,672 KB |
| 最終ジャッジ日時 | 2024-07-01 08:23:16 |
| 合計ジャッジ時間 | 4,979 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 33 |
コンパイルメッセージ
Main.rb:1: warning: assigned but unused variable - a Main.rb:2: warning: assigned but unused variable - a Main.rb:3: warning: assigned but unused variable - a Main.rb:28: warning: ambiguous first argument; put parentheses or a space even after `-' operator Syntax OK
ソースコード
def inp() a=gets.chomp.split(" ").map(&:to_i)end
def inpf() a=gets.chomp.split(" ").map(&:to_f)end
def inpss() a=gets.chomp.split(" ")end
def copy(a) Marshal.load(Marshal.dump(a)) end
def kaizyo(n)(n < 2)? 1 : (2..n).inject(:*) end
def scount(a) b=na(a.max+1);a.each{|n|b[n]+=1};return b end
def na(n,d=0) Array.new(n,d)end
def na2(n,m,d=0) Array.new(n){Array.new(m,d)}end
def na3(n,m,l,d=0) Array.new(n){Array.new(m){Array.new(l,d)}}end
def bit(n) n.to_s(2).split("").map(&:to_i) end
def cals(x,y,ax,ay,bx,by) ((ax-x)*(by-y)-(bx-x)*(ay-y)*-1)/2.to_f end
memo = {}
n = inp[0]
que = [[1,1]]
while(que.size != 0)
now = que.shift
next if(memo[now[0]]==1)
if(now[0] == n)
puts now[1]
exit
end
memo[now[0]] = 1
pu = now[0]+bit(now[0]).count(1)
que.push([pu,now[1]+1]) if(pu <= n)
mi = now[0]-bit(now[0]).count(1)
que.push([mi,now[1]+1]) if(mi > 0)
end
puts -1
=begin
=end
zazaboon