最終更新: 2011-03-12T03:46+0900
"exactly five"
memo = Hash.new{|h,k| h[k] = [] } n = 0 k_length = 1 loop{ n += 1 cube = n*n*n k = cube.to_s.split(//).sort.join('') if k.length != k_length answer = memo.values.select{|cubes| cubes.size == 5 } if not answer.empty? answer.each{|cubes| p cubes } exit end memo.clear k_length = k.length end memo[k] << cube }
# (x-1)/x <= log10(n) < 1 (n = ?,?,...) count = 0 x = 0 loop{ x += 1 boundary = (x-1.0)/x lower_bound = (1..9).to_a.reverse.find{|n| Math.log10(n) < boundary } || 0 count += 9 - lower_bound break if lower_bound == 9 } p count
またまた「Dreamshire | Project Euler Problem 63 Solution」の解答を検討してみたい。二重のル
というスト
ともあれ、明かされてみればワンライナ
p (1..9).inject(0){|sum,n| sum + (1/(1-Math.log10(n))).floor }
常用対数を直接求めるメソ
連分数a += 1 while 0 <= r - (n - d*(a+1))**2
の条件部分が判然としない。スクリプト中のコメントにあるように、対象としてるル
def next_frac(r, n, d) # (√r + n) / d = a + 1 / [(√r + n_) / d_] a = 0 a += 1 while 0 <= r - (n - d*(a+1))**2 d_ = (r - (n - d*a)**2) / d raise if (r - (n - d*a)**2) % d != 0 # why OK? n_ = -(n - d*a) return a, r, n_, d_ end def period_of(r) rnd = [r, 0, 1] arr = [] loop{ a, *rnd = next_frac(*rnd) arr << rnd period = arr.size-1 - arr.index(rnd) return period if 0 != period return 0 if rnd[2] == 0 # √r is rational. } end count = 0 1.upto(10000){|n| count += 1 if period_of(n) % 2 == 1 } p count
ところで、この問題を解くときに Math.sqrtを使うの
最終更新: 2011-03-04T22:27+0900
認証結果(GET/POSTデ
Bloggerの解。
表示名には、OpenID プロバイダから Google に送信されたあなたの名前が使用されます。表示名がない場合は、OpenID の URL から表示名の取得を試みます。
Blogger で OpenID を使用してコメントを書き込む - Blogger ヘルプ
こういう割り切りが必要なのかな。でも Yahoo!!!なんかは味気ない URLしか返してこないよね(※1)。mixiしか聞かない、表示名が取得できた
※1 知らぬ間に AX(Attribute Exchange)に対応してた。「Yahoo! JAPAN、OpenIDでプロフ
※2 も
閑話休題。nonceをワンタイムでなく時限式にするしかないのだろうか。タイムアウト
OpenID Providerへコメントの全文ごとユ
最終更新: 2011-03-02T05:24+0900
何も考えずにコ
generators = [ lambda{ n = 0 lambda{ n+=1; n*(n+1)/2 } }.call, lambda{ n = 0 lambda{ n+=1; n*n } }.call, lambda{ n = 0 lambda{ n+=1; n*(3*n-1)/2 } }.call, lambda{ n = 0 lambda{ n+=1; n*(2*n-1) } }.call, lambda{ n = 0 lambda{ n+=1; n*(5*n-3)/2 } }.call, lambda{ n = 0 lambda{ n+=1; n*(3*n-2) } }.call, ] # 数を準備 d4polynumbers = generators.map{|g| () while (p = g.call) < 1000 a = [p] a.push(p) while (p = g.call) < 10000 a } # 端緒(の集まり) bunch_of_chain = d4polynumbers[d4polynumbers.size-1].map{|p| [[p, d4polynumbers.size-1]] } # 端緒を伸ばすもの extender = lambda{|chain, pool| xx = chain.last.first.to_s[-2,2] ( (0...(pool.size)).to_a - chain.map{|_| _.last } ).map{|i| [i, pool[i]] }.map{|i, nums| nums.find_all{|num| num.to_s[0,2] == xx }.map{|num| chain + [[num, i]] } }.inject(&:+) } # 伸ばしていく (d4polynumbers.size-1).times{ bunch_of_chain = bunch_of_chain.map{|chain| extender[chain, d4polynumbers] }.inject(&:+) } # 輪っか? bunch_of_cyclic_chain = bunch_of_chain.reject{|chain| chain.first.first.to_s[0,2] != chain.last.first.to_s[-2,2] } # 出力 bunch_of_cyclic_chain.each{|chain| puts chain.map{|a,_| a }.join("\t") puts chain.map{|_,b| "P#{b+3}" }.join("\t") puts "sum: #{chain.map{|a,_| a }.inject(&:+)}" }
先は長いのにもう失速してる。「良いもの。悪いもの。: Project Eulerを100問解いてみた」テトレ
中学生の時に の一の位は何かという問題が出た。でも Problem 188は何乗したらいいかもわからない。下手の考え休むに似たり
最終更新: 2011-08-08T21:28+0900
目当てはペルソナ機能。OpenIDは自分が何者かを名乗るためのもので、また他人に自分の名を騙らせないためのものだと思
OpenIDについて認証結果(Webアプリに対する GET/POSTリクエスト)の改ざんを防ぐ仕組みと再利用を防ぐ仕組みを勉強した。再利用が悪なのかはわからないけど。
日記デ
Cookieには openid.claimed_idを保存しておいて、ダメ元で JavaScriptに immediateモ