結果
| 問題 | No.2 素因数ゲーム |
| コンテスト | |
| ユーザー |
horiesiniti
|
| 提出日時 | 2018-04-01 10:24:10 |
| 言語 | Ruby (3.4.1) |
| 結果 |
AC
|
| 実行時間 | 120 ms / 5,000 ms |
| コード長 | 517 bytes |
| コンパイル時間 | 322 ms |
| コンパイル使用メモリ | 7,424 KB |
| 実行使用メモリ | 12,160 KB |
| 最終ジャッジ日時 | 2024-12-26 13:28:56 |
| 合計ジャッジ時間 | 5,296 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 31 |
コンパイルメッセージ
Syntax OK
ソースコード
def f(n,arr,dp,v)
if n==1
return v
else
if dp.key?([v,n])!=false
return dp[[v,n]]
end
arr.size.times{|i|
t=arr[i]
if n%t==0
s=f(n/t,arr,dp,1-v)
if v!=s
dp[[v,n]]=s
return s
end
end
}
dp[[v,n]]=v
return dp[[v,n]]
end
end
n=gets.to_i
n2=n
d=2
arr=[]
while d*d<=n
if n%d==0
d2=d
while n%d == 0
n/=d
arr<<d2
d2*=d
end
end
d+=1
end
if n>1
arr<<n
end
arr=arr.uniq
dp={}
if arr.size==0
puts "Alice"
else
puts ["Bob","Alice"][f(n2,arr,dp,0)]
end
horiesiniti