2008-04-15
■n個のべき乗の合成
http://blog.koshigoe.jp/archives/2008/04/n2.html
Pythonではべき乗が**なので置き換えさせてもらうことにする。
>>> 2 2 >>> 2 ** 2 4 >>> 2 ** 2 ** 2 16 >>> (2 ** 2) ** 2 16 >>> 2 ** (2 ** 2) 16
ここまではいいのだけど、4番目から結合の順序によって結果が変わるようになる。
>>> ((2 ** 2) ** 2) ** 2 256 >>> 2 ** (2 ** (2 ** 2)) 65536
累乗は結合法則をみたさない、というわけなので、まずはどっちの結果を期待しているか明確にしないと行けないんじゃなかろうか。
ちなみにPythonだと後者。
>>> 2 ** 2 ** 2 ** 2 65536
数学的に簡潔に各方法は知らないけど、Pythonコードで簡潔に書くのならこうかな。
>>> reduce(lambda x, y: y ** x, [2L] * 4)
65536L
トラックバック - http://d.hatena.ne.jp/nishiohirokazu/20080415/1208250014
リンク元
- 47 http://74.125.153.132/search?q=cache:IRNCkbwOH-sJ:d.hatena.ne.jp/nishiohirokazu/20080415/1208254884+"to+mock+a+mockingbird"&cd=2&hl=ja&ct=clnk&gl=jp&lr=lang_ja&client=firefox-a
- 31 http://www.google.co.jp/search?q=To+Mock+a+Mockingbird&ie=utf-8&oe=utf-8&aq=t&rls=com.ubuntu:ja:unofficial&client=firefox-a
- 28 http://reader.livedoor.com/reader/
- 22 http://b.hatena.ne.jp/entry/http://d.hatena.ne.jp/Yoshiori/20080415/1208246288
- 22 http://www.google.co.jp/search?q=to+mock+a+mockingbird&lr=lang_ja&ie=utf-8&oe=utf-8&aq=t&rls=org.mozilla:ja:official&client=firefox-a
- 13 http://www.google.co.jp/search?hl=ja&source=hp&q=To+mock+a+mockingbird&btnG=Google+検索&lr=&aq=f&oq=
- 10 http://www.google.co.jp/search?sourceid=navclient&hl=ja&ie=UTF-8&rlz=1T4GFRD_jaJP224JP225&q=WiimoteLib.dll
- 9 http://twitter.com/home
- 9 http://www.google.co.jp/search?q=maketrans&ie=utf-8&oe=utf-8&aq=t&rls=com.ubuntu:ja:unofficial&client=firefox-a
- 9 http://www.nishiohirokazu.org/