-
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
- Arch. Prog. Nieuprzywilejowanych w pełnej wer. na nowej s. WWW energokod.pl
- 7. Raport Totaliztyczny: Sprawa Qt Group wer. 424
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
- sprawdzanie słów kluczowych dot. zła
- Re: W czym sie teraz pisze programy??
- Re: (PDF) Surgical Pathology of Non-neoplastic Gastrointestinal Diseases by Lizhi Zhang
- CfC 28th Ada-Europe Int. Conf. Reliable Software Technologies
Najnowsze wątki
- 2025-01-06 Do IO i innych elektrooszolomow, tu macie prawdziwe smrody
- 2025-01-06 Białystok => Full Stack .Net Engineer <=
- 2025-01-06 Kraków => Business Development Manager - Network and Network Security
- 2025-01-06 Katowice => Regionalny Kierownik Sprzedaży (OZE) <=
- 2025-01-06 Warszawa => Spedytor Międzynarodowy <=
- 2025-01-06 Lublin => Programista Delphi <=
- 2025-01-06 Gdańsk => Specjalista ds. Sprzedaży <=
- 2025-01-06 śnieg
- 2025-01-05 Żarówka do lampy z czujnikiem ruchu
- 2025-01-05 Rozkręcają się
- 2025-01-04 pozew za naprawę sprzętu na youtube
- 2025-01-04 gasik
- 2025-01-04 13. Raport Totaliztyczny: Powszechna Deklaracja Praw Człowieka Nie Chroni Przed Wyzyskiem Ani Przed Eksploatacją
- 2025-01-04 Zbieranie danych przez www
- 2025-01-04 reverse engineering i dodawanie elementów do istniejących zamkniętych produktów- legalne?