Thread grosse hashes optimieren: 800-900 keys (19 answers)
Opened by lichtkind at 2006-06-21 22:38

Ishka
 2006-06-22 22:51
#67530 #67530
User since
2003-08-04
771 Artikel
HausmeisterIn
[Homepage] [default_avatar]
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}

View full thread grosse hashes optimieren: 800-900 keys