-
Path: news-archive.icm.edu.pl!agh.edu.pl!news.agh.edu.pl!newsfeed2.atman.pl!newsfeed.
atman.pl!.POSTED!not-for-mail
From: bartekltg <b...@g...com>
Newsgroups: pl.comp.programming
Subject: Re: funkcja haszująca/skrótu
Date: Tue, 24 Sep 2013 06:06:20 +0200
Organization: ATMAN - ATM S.A.
Lines: 58
Message-ID: <l1r34o$7qe$1@node2.news.atman.pl>
References: <l1q5qe$d61$1@node2.news.atman.pl>
<5...@g...com>
<l1qgp1$dpi$1@node1.news.atman.pl>
NNTP-Posting-Host: 89-76-68-230.dynamic.chello.pl
Mime-Version: 1.0
Content-Type: text/plain; charset=UTF-8; format=flowed
Content-Transfer-Encoding: 8bit
X-Trace: node2.news.atman.pl 1379995608 8014 89.76.68.230 (24 Sep 2013 04:06:48 GMT)
X-Complaints-To: u...@a...pl
NNTP-Posting-Date: Tue, 24 Sep 2013 04:06:48 +0000 (UTC)
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:17.0) Gecko/20130801
Thunderbird/17.0.8
In-Reply-To: <l1qgp1$dpi$1@node1.news.atman.pl>
Xref: news-archive.icm.edu.pl pl.comp.programming:204535
[ ukryj nagłówki ]W dniu 2013-09-24 00:53, Piotrne pisze:
> W dniu 2013-09-23 22:35, Wojciech Muła pisze:
>
>> No dobra, a dlaczego nie możesz posługiwać się piątką liczb 1..52
>> i potraktować je jako cyfry dla systemu liczenia o podstawie 52?
>> Wtedy miałbyś od razu indeks do tablicy, kosztem 5 mnożeń i 4 dodawań.
>
> Przypuszczam, z powodem jest 52^5 = 380204032, większe od 2,5 miliona.
>
>
>> Jeśli to jednak nie przejdzie, to może lepiej rozważ użycie drzew
>> trie.
>
>
>
> Napisałem funkcję c2num, która wykonuje przekształcenie, o które pytał
> autor wątku. W funkcji używane są współczynniki dwumianowe, które
> oczywiście można stablicować zamiast liczyć za każdym razem.
Pytacz pewnie by docenił dwa słowa, skąd wzorek;)
Współczynniki pewnie rzeczywiście najłatwiej stablicować,
na pewno nie mogą zostać tak:
> /* Współczynnik dwumianowy */
> int binom(int n, int k)
> { if ((k==0) || (k==n)) return 1; else return
> binom(n-1,k-1)+binom(n-1,k); }
Odpalenie binom(n,k) oznacza odpalenie tej funkcji
rekurencyjnie C(n,k)*2-1 razy. Dla n=52 i k=26 to 9.9*10^14 razy.
:-)
Lepszym, a nadal prostym wzorkiem jest np 12 stąd:
http://mathworld.wolfram.com/BinomialCoefficient.htm
l
C(n; k+1) = ( C(n; k) * (n-k) ) / (k+1)
plus C(n;0)=1 oczywiście.
nawiązując do oryginalnego pytania:
Piotrne wykorzystał tutaj postać liczb. Nie zawsze się
tak da, Ale nawet, jeśli nasze liczby sa losowe nie wszytko
stracone, nadal możemy zbudować doskonałą funkcję haszującą,
kosztem oczywiście pamięci.
Date: Thu, 7 Mar 2013 19:10:04 -0800 (PST)
Message-ID: <3...@g...c
om>
Subject: w poszukiwaniu funkcji hash
i hasełko perfect hash.
Można też brutalniej. Zapisać wszystkie liczby 'pięciobinarne',
posortować, a potem indeksu szukać binarnie. Obstawiam jednak,
że wzorek będzie szybszy.
pzdr
bartekltg
Następne wpisy z tego wątku
- 24.09.13 14:13 Piotrne
- 25.09.13 07:56 Przemysłąw Dębski
- 25.09.13 12:36 JDX
- 25.09.13 15:05 p...@g...pl
- 25.09.13 17:30 JDX
- 25.09.13 19:01 Ghost
Najnowsze wątki z tej grupy
- Can you activate BMW 48V 10Ah Li-Ion battery, connecting to CAN-USB laptop interface ?
- We Wrocławiu ruszyła Odra 5, pierwszy w Polsce komputer kwantowy z nadprzewodzącymi kubitami
- Ada-Europe - AEiC 2025 early registration deadline imminent
- John Carmack twierdzi, że gdyby gry były optymalizowane, to wystarczyły by stare kompy
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2025
- Linuks od wer. 6.15 przestanie wspierać procesory 486 i będzie wymagać min. Pentium
- ,,Polski przemysł jest w stanie agonalnym" - podkreślił dobitnie, wskazując na brak zamówień.
- Rewolucja w debugowaniu!!! SI analizuje zrzuty pamięci systemu M$ Windows!!!
- Brednie w wiki - hasło Dehomag
- Perfidne ataki krakerów z KRLD na skrypciarzy JS i Pajton
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- U nas propagują modę na SI, a w Chinach naukowcy SI po kolei umierają w wieku 40-50lat
- C++. Podróż Po Języku - komentarz
Najnowsze wątki
- 2025-07-14 granice
- 2025-07-14 Awaria VM?
- 2025-07-14 Gdańsk => Programista Kotlin <=
- 2025-07-14 Warszawa => Junior Rekruter <=
- 2025-07-14 Warszawa => Specjalista rekrutacji IT <=
- 2025-07-14 Wkłady do zniczy...
- 2025-07-14 Warszawa => Specjalista ds. Sprzętu Komputerowego <=
- 2025-07-14 Re: PO chroniło i chroni policyjnych bandziorów [zawiasy za katowanie obywatela (Poznań czerwiec 2012)]
- 2025-07-14 Warszawa => International Freight Forwarder <=
- 2025-07-14 Warszawa => Recruiter 360 <=
- 2025-07-14 Re: Rz?Âd ZAKAZUJE magazyn?Â?w energii ?!! Nowe prawo od 14 lipca to SZOK! ??Â
- 2025-07-14 Warszawa => Sales Assistant <=
- 2025-07-13 Fałszywe alerty
- 2025-07-12 dlaczego gadacie z tym debilem
- 2025-07-13 Unia Europejska przygotowuje nowy podatek