Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS è il principale operatore di servizi cloud al mondo e da tempo parla delle misure che mette in atto per garantire una maggiore sovranità alle organizzazioni europee. L'azienda ha ora lanciato AWS European Sovereign Cloud, una soluzione specificamente progettata per essere separata e distinta dal cloud "normale" e offrire maggiori tutele e garanzie di sovranità
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 19-06-2008, 11:42   #1
m0linas
Member
 
L'Avatar di m0linas
 
Iscritto dal: Feb 2008
Città: PoggibonZi
Messaggi: 140
[HASHING-teoria] Indirizzamento aperto, come funziona?

Ciao a tutti, spero di aver trovato la sezione giusta, anche se la mia non è una domanda su uno specifico linguaggio, ma su una struttura dati....Studiando le tabelle hash o trovato che ci sono 2 modi di gestire le collisioni, le liste di trabocco e l'indirizzamento aperto. Ora sulle prime nessuna difficoltà, ma non riesco a capire come funziona l'indirizzamento aperto....Ho cercato anche su google, ma ho trovato solo spiegazioni identiche a quelle del mio libro...Vi sarei grato se qualcuno potesse spiegarmelo in breve, magari facendo un esempio nel caso ho (buttiamola li) 5 chiavi K1=10 K2=7 K3=20 K4=3 k5=30 e la funzione hash sia hash(K)=k%10. In questo caso la funzione hash genera lo stesso risultato (0) su K1, K2 e K3. Come vengono memorizzati nell'array le chiavi?
Spero che qualcuno di voi abbia 5 minuti da dedicarmi, dato che questa schifosissima domanda mi ha fatto segare l'esame di algoritmi ieri
__________________
Ho felicemente trattato con: Isomarcus, NLDomy, cipacci.

Intel e2180 @ 3.1Ghz + Arctic Cooling Freezer 7 ~ MSI P35 Neo2-FR ~ Geil Black Dragon @ 970Mhz 4-4-4-12 ~ ASUS 8800GT 512Mb ~ OCZ StealthXtream 500W
m0linas è offline   Rispondi citando il messaggio o parte di esso
Old 21-06-2008, 13:19   #2
m0linas
Member
 
L'Avatar di m0linas
 
Iscritto dal: Feb 2008
Città: PoggibonZi
Messaggi: 140
Nessuno lo sa? Mi fareste un grosso favore...
__________________
Ho felicemente trattato con: Isomarcus, NLDomy, cipacci.

Intel e2180 @ 3.1Ghz + Arctic Cooling Freezer 7 ~ MSI P35 Neo2-FR ~ Geil Black Dragon @ 970Mhz 4-4-4-12 ~ ASUS 8800GT 512Mb ~ OCZ StealthXtream 500W
m0linas è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2008, 11:35   #3
m0linas
Member
 
L'Avatar di m0linas
 
Iscritto dal: Feb 2008
Città: PoggibonZi
Messaggi: 140
__________________
Ho felicemente trattato con: Isomarcus, NLDomy, cipacci.

Intel e2180 @ 3.1Ghz + Arctic Cooling Freezer 7 ~ MSI P35 Neo2-FR ~ Geil Black Dragon @ 970Mhz 4-4-4-12 ~ ASUS 8800GT 512Mb ~ OCZ StealthXtream 500W
m0linas è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2008, 13:30   #4
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
I dati relativi alle collisioni non vengono memorizzate in una lista privata per ogni chiave (come avviene per il separate Chaining), ma vengono posizionati direttamente dentro l'array, in celle alternative ma ben specifiche.
Un po' come dire
Scelta la funzione di hashing f(data)=key mappa ogni valore desiderato in una chiave ben precisa.
Se pero' la cella relativa alla chiave ben specifica e' gia' occupata, allora per questa, ma solo per questa, la funzione di hash diventa g(data)=new key.
Se anche la g(data) e' occupata, proviamo con la h(data).
e cosi' via.

Solitamente la funzione che trasforma da f(data) in g(data) (e poi in h(data) e cosi' via) e' una funziona ancora piu' semplice di quella di hashing. Viene chiamata funzione di Probing, e potrebbe essere banalmente = "Provo la cella successiva a quella restituita dalla funzione di hashing".
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2008, 18:07   #5
m0linas
Member
 
L'Avatar di m0linas
 
Iscritto dal: Feb 2008
Città: PoggibonZi
Messaggi: 140
Ok, grazie millemila
Immaginavo una cosa del genere, ma sul mio libro di testo è spiegato piuttosto male....
Grazie ancora, il mondo sarebbe migliore se ci fosse più gente come te

EDIT: ormai che ci sei mi potresti scrivere come risulterebbe l'array nell'esempio che avevo fatto io nel primo post? Ponendo come funzione di probing hash(data)=key + 1 se la posizione è già occupata dovrebbe venire una cosa del genere(null indica una posizione vuota):

indice 0----1---2---3----4----5----6----7----8..............
array [10] [20] [30] [3] [null] [null] [null] [7] [null.................]

Se a questo punto avessi k6=40....dato che 40%10=0, andrei a memorizzare 40 in array[4] dato che è il primo posto libero?
__________________
Ho felicemente trattato con: Isomarcus, NLDomy, cipacci.

Intel e2180 @ 3.1Ghz + Arctic Cooling Freezer 7 ~ MSI P35 Neo2-FR ~ Geil Black Dragon @ 970Mhz 4-4-4-12 ~ ASUS 8800GT 512Mb ~ OCZ StealthXtream 500W

Ultima modifica di m0linas : 24-06-2008 alle 18:21.
m0linas è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2008, 18:43   #6
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Quote:
Originariamente inviato da m0linas Guarda i messaggi
Se a questo punto avessi k6=40....dato che 40%10=0, andrei a memorizzare 40 in array[4] dato che è il primo posto libero?
Esattamente.
Questo e' il comportamento piu' semplice. (first wins, da usarsi quando le scritture sono pesanti, oppure quando si pensa che i primi dati siano quelli piu' richiesti)

Ci sono altri criteri che si possono adottare in caso di collisione.
Potresti decidere che vince l'ultimo inserito, e non quello che c'e', che e' quindi quello spostato. (last wins, da usarsi quando e' piu' probabile che siano i nuovi dati ad essere letti piuttosto che i vecchi)
Oppure potersti decidere che vince quello per cui sono necessarie meno "salti" in caso di ricerca. (least read effort)

Criteri analoghi sono applicabili anche nel caso di Separate Chaining.
Potresti decidere di appendere il nuovo arrivato in fondo, oppure di metterlo in testa. Oppure di tenere la lista ordinata. oppure boh?

Nel caso di ricerca invece, poni di aver inserito il valore 40, nella posizione 4.
Se successivamente ti dovessi chiedere: "Esiste il valore 40 nella mia hashtable"?
Allora procederai come segue:
Calcolo la hash di 40 = 0
Cominicio a scandire l'array a partire da questo indice.
Se trovo 40, restituisco true.
Se trovo NULL, restituisco false.
Altrimenti continuo a scandire.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 25-06-2008, 16:52   #7
m0linas
Member
 
L'Avatar di m0linas
 
Iscritto dal: Feb 2008
Città: PoggibonZi
Messaggi: 140
ok, grazie mille! Ciao
__________________
Ho felicemente trattato con: Isomarcus, NLDomy, cipacci.

Intel e2180 @ 3.1Ghz + Arctic Cooling Freezer 7 ~ MSI P35 Neo2-FR ~ Geil Black Dragon @ 970Mhz 4-4-4-12 ~ ASUS 8800GT 512Mb ~ OCZ StealthXtream 500W
m0linas è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Addio limiti di packaging? Intel mostra ...
Disastro Williams: la FW48 non supera l'...
Un hotel italiano fa incetta di recensio...
OnePlus Nord 5 in super offerta su Amazo...
L'innovazione in tournée: arrivan...
Addio al caos dei gruppi Whatsapp: arriv...
Il nuovo chip a 2 nm di Samsung si mostr...
IBM Enterprise Advantage: consulenza per...
Samsung celebra Milano Cortina 2026 con ...
Aritmie cardiache, cresce il numero di c...
Rinviato il secondo lancio del razzo spa...
iPhone 18 Pro: Dynamic Island più...
Pazzesco successo di Xiaomi: la nuova SU...
Il terzo lancio del razzo spaziale Blue ...
Tesla toglie la componente umana dai Rob...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 08:59.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v