[#39804] CGIでのリダイレクションの書き方 — Yoichiro Takehora <yoichiro@...>
こんにちは、竹洞です。
7 messages
2004/07/02
[#39811] keyword-argument-like argument passing via Hash — NISHIMATSU Takeshi <t-nissie@...>
西松と申します.
4 messages
2004/07/02
[#39814] Socket:IPヘッダの編集方法 — takeshi honda <moecho21@...>
本田と申します。
6 messages
2004/07/02
[#39819] [ANN] Ruby-GetText-Package-0.6.0 — Masao Mutoh <mutoh@...>
むとうです。
4 messages
2004/07/04
[#39822] (要素がString, Fixnum 以外の)配列の集合演算 — Hiroshi Takagi <gollum@...>
高木といいます、よろしく。
11 messages
2004/07/05
[#39823] Re: (要素がString, Fixnum 以外の)配列の集合演算
— 卜部昌平 <s-urabe@...>
2004/07/05
mput です。
[#39824] Re: (要素がString, Fixnum 以外の)配列の集合演算
— Hiroshi Takagi <gollum@...>
2004/07/05
高木です。
[#39826] Re: (要素がString, Fixnum 以外の)配列の集合演算
— nobu.nakada@...
2004/07/06
なかだです。
[#39856] 直接関係のない配列の有無が、ある配列の値に影響する不具合 — "Hisashi Yahata" <yahatah@...>
5 messages
2004/07/17
[#39863] forループの速度 — Masahiro Sato <msato@...>
15 messages
2004/07/20
[#39868] イテレータとfor文 — OOTANI TAKASHI <otn@...5.so-net.ne.jp>
大谷と申します。
31 messages
2004/07/20
[#39870] Re: イテレータとfor文
— Nowake <nowake@...>
2004/07/20
[#39886] Re: イテレータとfor文
— Tietew <tietew-ml-ruby-list@...>
2004/07/21
[#39891] Re: イテレータとfor文
— OOTANI TAKASHI <otn@...5.so-net.ne.jp>
2004/07/21
大谷です。
[#39910] Re: イテレータとfor文
— Atoh <atoh@...7.jp>
2004/07/23
あとうです。
[#39911] Re: イテレータとfor文
— OOTANI TAKASHI <otn@...5.so-net.ne.jp>
2004/07/23
大谷です。
[#39889] dRuby: 急に遅くなる — ちば けいすけ <chowder@...>
ちばです。
7 messages
2004/07/21
[#39908] htreeの高速化 — MoonWolf <moonwolf@...>
MoonWolfです。
6 messages
2004/07/23
[ruby-list:39835] Re: (要素がString, Fixnum 以外の)配列の集合演算
From:
Hiroshi Takagi <gollum@...>
Date:
2004-07-06 13:54:15 UTC
List:
ruby-list #39835
高木です。
On Tue, 6 Jul 2004 19:54:37 +0900
卜部昌平 <s-urabe@par.odn.ne.jp> wrote:
> だからといってHashの方が高速とは一概に言えないあたりがO記法の難しいところなわけで、以下のような実験をすると、実用的な状況では配列そのもの
> の方が速いのではないかと.... 何十個もインスタンス変数があるようなのは稀だと思いますし。
実際に業務で作成していたクラスもインスタンス変数は 8個でした。
(20個程度にはなるものも出てくるかも...)
4000程度のobject の配列(集合)を二つ作って、
集合演算をいろいろとやってみましたが、
たしかにこの程度では、Array で実装した方が少し早い結果が出ました。
> require 'benchmark'
>
> (1..32).each do |i|
> foo = Foo.new(i)
> bar = Foo.new(i)
> t1 = Benchmark.realtime { 2048.times { foo.eql1(bar) } }
> t2 = Benchmark.realtime { 2048.times { foo.eql2(bar) } }
> printf("%2d %s faster\n", i, t1>t2 ? "array":" hash")
> STDOUT.flush
> end
Benchmark の使い方がとても参考になりました。
ありがとうございました。
最初のreply をいただいて、動的プログラムに走ろうとしてたんですが、
1.8 の機能を使うとevalぁずにすんだのがなんだかうれしい :-)
--
Hiroshi Takagi <gollum@hi-net.zaq.ne.jp>