Thread grosse hashes optimieren: 800-900 keys
(19 answers)
Opened by lichtkind at 2006-06-21 22:38
Das klappt auch im Allgemeinen nicht. Lediglich, wenn du dir deine Schlüssel so aussuchst, daß sie auf den Hash-Algorithmus passt, kommst du auf O(1), aber das tun vorgegebene Werte leider selten ;)
O(ln x) ist für den allgemeinen Fall das schnellste, was man hinbekommen kann. sub z{if(@_){1while$x[$k=rand 10];t($t=$x[$k]=1)}print map"$z[$x[$_]]$_".($_%3?
"":"\n"),1..9}sub t{$j=0;$x[$_+1]==$t&&($j+=2**$_)for 0..8;z,die"Gewinner $z[$t] "if grep$_==($j&$_),7,56,73,84,146,273,292,448;z,die"Gleichstand\n"if@x>9&&!grep !$_,@x}@x=4;@z=qw{. [ (};z$^T&1;while(<>){next if$_>9||$x[$_];t$t=$x[$_]=2;z 1} |