-
X-Received: by 10.49.25.13 with SMTP id y13mr37676qef.2.1362712204797; Thu, 07 Mar
2013 19:10:04 -0800 (PST)
X-Received: by 10.49.25.13 with SMTP id y13mr37676qef.2.1362712204797; Thu, 07 Mar
2013 19:10:04 -0800 (PST)
Path: news-archive.icm.edu.pl!agh.edu.pl!news.agh.edu.pl!newsfeed2.atman.pl!newsfeed.
atman.pl!newsfeed.neostrada.pl!unt-exc-01.news.neostrada.pl!newsfeed.pionier.ne
t.pl!news.glorb.com!t2no9942720qal.0!news-out.google.com!o5ni47qas.0!nntp.googl
e.com!dd2no8152372qab.0!postnews.google.com!glegroupsg2000goo.googlegroups.com!
not-for-mail
Newsgroups: pl.comp.programming
Date: Thu, 7 Mar 2013 19:10:04 -0800 (PST)
Complaints-To: g...@g...com
Injection-Info: glegroupsg2000goo.googlegroups.com; posting-host=178.37.225.252;
posting-account=xjvq9QoAAAATMPC2X3btlHd_LkaJo_rj
NNTP-Posting-Host: 178.37.225.252
User-Agent: G2/1.0
MIME-Version: 1.0
Message-ID: <3...@g...com>
Subject: w poszukiwaniu funkcji hash
From: "M.M." <m...@g...com>
Injection-Date: Fri, 08 Mar 2013 03:10:04 +0000
Content-Type: text/plain; charset=ISO-8859-2
Content-Transfer-Encoding: quoted-printable
Xref: news-archive.icm.edu.pl pl.comp.programming:202162
[ ukryj nagłówki ]
Zastanawiam się, czy istnieje wydajny algorytm, albo może
wręcz jakaś metoda analityczna, do budowy różnowartościowych
funkcji hash.
Mamy zbiór X, elementami zbioru X jest N liczb
całkowitych x_i. Zwykle N jest większe od 10 i mniejsze
od 10tys. Liczby całkowite x_i zwykle należą do przedziału
od -10^6 do +10^6. Trzeba znaleźć różnowartościową
funkcję h, która odwzoruje wszystkie elementy X w ciąg
liczb naturalnych od 1 do M. Idealnie jakby M było
równe N, ale jeśli M < N*3 to też nie będzie źle.
Chodzi o to, aby funkcja h była możliwie prosta i
żeby dało się ją wydajnie zaimplementować. Przykładem
funkcji h może być:
h( x_i ) = ( (x_i + a_1 ) * (x_i + a_2) * ... * (x_i + a_n) ) % M;
gdzie n jest możliwe małe, najlepiej gdy 2<=n<=3.
Moje pytanie sprowadza się do tego, czy istnieje efektywny
algorytm, który na wejście otrzyma parę: zbiór X i M, a
na wyjściu poda a_1, a_2, a_n.
Oczywiście funkcja h nie musi być taka jak podałem w
przykładzie, może lepiej sprawdzi się operacja xor:
h( x_i ) = ( (x_i xor a_1 ) * (x_i xor a_2) * ... * (x_i xor a_n) ) % M;
Trzeba przeiterować po wszystkich a_i żeby dowiedzieć się
czy dla danego X i M istnieje różnowartościowa funkcja H,
czy można to jakoś sprawniej osiągnąć?
Pozdrawiam
Następne wpisy z tego wątku
- 08.03.13 23:38 Wojciech Muła
- 09.03.13 00:25 M.M.
- 10.03.13 15:33 Wojciech Muła
- 10.03.13 23:42 M.M.
Najnowsze wątki z tej grupy
- Grok zaczął nadużywać wulgaryzmów i wprost obrażać niektóre znane osoby
- 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
Najnowsze wątki
- 2025-07-19 Zakrzewo => SAP HCM Consultant <=
- 2025-07-19 Poznań => Konsultant SAP HCM <=
- 2025-07-19 Poznań => SAP HCR Consultant <=
- 2025-07-18 celnicy pobili policjanta
- 2025-07-18 Warszawa => Technik IT - Konfiguracja i Wsparcie Sprzętowe <=
- 2025-07-18 Warszawa => Specjalista ds. Sprzętu IT i Wsparcia Technicznego <=
- 2025-07-18 Białystok => Kotlin Developer <=
- 2025-07-18 Warszawa => Sales Director (Cloud solutions) <=
- 2025-07-18 Spalinowa trauma
- 2025-07-18 Polska => Senior Key Account Manager <=
- 2025-07-18 Białystok => Programista Kotlin <=
- 2025-07-18 Szczecin => Key Account Manager IT <=
- 2025-07-18 Łódź => Programista Mainframe (z/OS, Assembler) <=
- 2025-07-18 Łódź => Mainframe (z/OS, Assembler) Developer <=
- 2025-07-18 Lublin => Delphi Programmer <=