Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Xiaomi ha portato Redmi Watch 6 anche sul mercato italiano, puntando su un display AMOLED da 2,07 pollici con picco di luminosità a 2000 nit, frame in alluminio da 9,9mm e un'autonomia dichiarata di 12 giorni. Lo smartwatch gira su HyperOS 3 e integra GPS, Bluetooth 5.4 e oltre 150 sport mode. Il tutto a meno di 100 euro
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti
Con 22 tasti, il pulsante 5D, lo Shift Mode e il sensore PixArt 3395 da 26.000 DPI, il nuovo mouse wireless di Mad Catz si rivolge in modo preciso ai giocatori di MMO e RPG. Ma chi conosce già il R.A.T. 8+ ADV si accorgerà subito di quanto i due prodotti condividano, e di dove invece divergono
Radeon RX 9070 GRE, AMD la porta in tutto il mondo | Recensione Gigabyte Gaming OC
Radeon RX 9070 GRE, AMD la porta in tutto il mondo | Recensione Gigabyte Gaming OC
Abbiamo provato la Gigabyte Radeon RX 9070 GRE Gaming OC, nuova proposta RDNA 4 che si inserisce tra GeForce RTX 5060 Ti e RTX 5070. Prestazioni solide in rasterizzazione e ray tracing, frequenze elevate grazie all'overclock di fabbrica e raffreddamento efficace: ecco come si comporta nei nostri test.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 10-12-2007, 22:28   #1
3nigma666
Senior Member
 
L'Avatar di 3nigma666
 
Iscritto dal: Jan 2005
Città: A casa mia
Messaggi: 825
hash Table: Delirio

Mi sto studiando le Hash Table... ma non c'ho capito un c*zzo..

Si, ovviamente ho compreso il meccanismo principe:

Hai un insieme Universo di Chiavi , la funzione h, fa si che: h: k --> ( 1 .... m )

Dome m sono gli slot di un array.

Allora fin qui è chiaro il meccanismo..se non fosse che:

1. non ho capito che sono ste chiavi, e da dove si ricavano o dove si ottengono

2.Il chaining non ho capito come funziona.

Del chaining so che ogni "slot" dell'array, invece che contenere un singolo elemento contiene una linked list.
si parla del chaining come metodo per diminuire le collisioni.
Si introduce quindi ALFA = n / m , dove alfa è detto FATTORE DI CARICO , e n rappresenta il numero di "slot" dell'array occupati e m il numero totale di slot, giusto ?

soprattutto , considerando che il costo di h(k) è O(1), xke il costo dell'hashing è TETA(1+ ALFA) ?!?!?

help .. please.. qualche anima pia mi spiega...
3nigma666 è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2007, 22:41   #2
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
Quote:
Originariamente inviato da 3nigma666 Guarda i messaggi
1. non ho capito che sono ste chiavi, e da dove si ricavano o dove si ottengono
le chiavi si ottengono tipicamente dal metodo hashcode, e servono per indicizzare gli oggetti(detto in modo spicciolo).
per favre un paragone vedi le chiavi dei db, ad ogni chiave corrisponde una ed una sola tupla.
ora proprio per "evitare" questo si usa il...
Quote:
Originariamente inviato da 3nigma666 Guarda i messaggi
2.Il chaining non ho capito come funziona.
praticamente tu non avrai una hashtable con tanti elemnenti quanti sono gli oggetti, tipo per 100 elementi avrai 10 oggetti dell'hashtable (da ora in poi HT)
quindi, facendo che inserisci gli oggetti in base alla loro decina di appartenenza, capirai che se inserisci 1 e 3, il 3 sovrasciverà l'1.

con il chaining tu crei una lista, dove metti elementi che creerebbero collisione, una specie di coda, in modo che tu accedi alla posizione che ti dice l'hashcode, se non trovi subito il tuo valore, loo cerchi nella coda.

sò di non essere stato chiarissimo, ma spero che tu riesca a comprende le mie insensate parole
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2007, 23:19   #3
3nigma666
Senior Member
 
L'Avatar di 3nigma666
 
Iscritto dal: Jan 2005
Città: A casa mia
Messaggi: 825
Quindi se ho capito bene:

Io ho delle chiavi (ovvero degli oggetti) che devo memorizzare all'interno di una tabella (o array) detta tabella di Hash.

Questo oggetto che devo memorizzare diventa, tramite la funzione di hash, un indice del vettore ove vado a memorizzare la chiave stessa.Tipo:

Chiave: "Antonio". Con la Funzione di Hash al nome antonio viene assegnato il numero 129. Nella tabella, alla funzione 129 viene memorizzato il nome "Antonio".

Nel caso in cui Due chiavi o piu chiavi mi danno come risultato 129, allora creo una lista di oggetti all'interno della tabella alla posizione 129.

Continuo a non capire completamente l'utilità. Nel senso che se l'oggetto che devo salvare nella tabella di hash è la chiave stessa, che senso ha fare questa operazione di trasformazione in indice ?
3nigma666 è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2007, 23:21   #4
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
Quote:
Originariamente inviato da 3nigma666 Guarda i messaggi
Quindi se ho capito bene:

Io ho delle chiavi (ovvero degli oggetti) che devo memorizzare all'interno di una tabella (o array) detta tabella di Hash.

Questo oggetto che devo memorizzare diventa, tramite la funzione di hash, un indice del vettore ove vado a memorizzare la chiave stessa.Tipo:

Chiave: "Antonio". Con la Funzione di Hash al nome antonio viene assegnato il numero 129. Nella tabella, alla funzione 129 viene memorizzato il nome "Antonio".

Nel caso in cui Due chiavi o piu chiavi mi danno come risultato 129, allora creo una lista di oggetti all'interno della tabella alla posizione 129.

Continuo a non capire completamente l'utilità. Nel senso che se l'oggetto che devo salvare nella tabella di hash è la chiave stessa, che senso ha fare questa operazione di trasformazione in indice ?
in linea di massima sì.

l'utilità???ricerche iperveloci (tramite il codice hash puoi utilizzare la ricerca binaria, ricerca in tempo logaritmico) e ottimizzzazione dello spazio di memoria(se ne spreca molto poco )
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2007, 23:21   #5
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
naturalmente sono i primi due che mi sono venuti in mente.....
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2007, 23:26   #6
3nigma666
Senior Member
 
L'Avatar di 3nigma666
 
Iscritto dal: Jan 2005
Città: A casa mia
Messaggi: 825
Quote:
Originariamente inviato da franksisca Guarda i messaggi
naturalmente sono i primi due che mi sono venuti in mente.....
forse mi sono espresso male.
Intendevo dire, in un esempio pratico, metti caso che voglio memorizzare in ram una stringa, tipo questa:" ciao "

Con l'hashing, Ciao viene trasformato in un indirizzo di memoria, tipo 123456 e, in questo stesso indirizzo, viene salvata la stringa ciao.

Se devo andare a controllare se la stringa ciao è salvata nella mia memoria ram sto un attimo, basta fare l'hash e vedere se la casella 123456 è occupata.

Quello che voglio capire io, è se con questo metodo io salvo effettivamente nell'array la chiave stessa ( infatti ho salvato la stringa CIAO nella posizione generata da H sulla stringa ciao ), o se si usa per salvare anche dati diversi dalla stringa stessa
3nigma666 è offline   Rispondi citando il messaggio o parte di esso
Old 11-12-2007, 08:13   #7
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
Quote:
Originariamente inviato da 3nigma666 Guarda i messaggi
forse mi sono espresso male.
Intendevo dire, in un esempio pratico, metti caso che voglio memorizzare in ram una stringa, tipo questa:" ciao "

Con l'hashing, Ciao viene trasformato in un indirizzo di memoria, tipo 123456 e, in questo stesso indirizzo, viene salvata la stringa ciao.

Se devo andare a controllare se la stringa ciao è salvata nella mia memoria ram sto un attimo, basta fare l'hash e vedere se la casella 123456 è occupata.

Quello che voglio capire io, è se con questo metodo io salvo effettivamente nell'array la chiave stessa ( infatti ho salvato la stringa CIAO nella posizione generata da H sulla stringa ciao ), o se si usa per salvare anche dati diversi dalla stringa stessa
allora nell'hashtable tu salvi 2 valori:

Key e Value, quindi salvi sia la chiave che il valore, che può essere una stringa o un oggetto qualsiasi

quindi se ho capito quello che dici....si, salvi anche la chiave!!!
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
Old 11-12-2007, 11:38   #8
3nigma666
Senior Member
 
L'Avatar di 3nigma666
 
Iscritto dal: Jan 2005
Città: A casa mia
Messaggi: 825
Quote:
Originariamente inviato da franksisca Guarda i messaggi
allora nell'hashtable tu salvi 2 valori:

Key e Value, quindi salvi sia la chiave che il valore, che può essere una stringa o un oggetto qualsiasi

quindi se ho capito quello che dici....si, salvi anche la chiave!!!
perfetto ti ringrazio
3nigma666 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro Redmi Watch 6 in prova: lo smartwatch con ampio ...
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ...
Radeon RX 9070 GRE, AMD la porta in tutto il mondo | Recensione Gigabyte Gaming OC Radeon RX 9070 GRE, AMD la porta in tutto il mon...
Reolink OMVI 3i WiFi: videosorveglianza più intelligente e facile da usare Reolink OMVI 3i WiFi: videosorveglianza pi&ugrav...
Recensione Vivo X300 Ultra: fotocamera eccezionale, ma prezzo proibitivo Recensione Vivo X300 Ultra: fotocamera ecceziona...
Virgin Galactic torna a far volare lo sp...
La sonda spaziale marziana NASA MAVEN &e...
Nucleare in Italia, approvata la legge d...
Surface Pro, nuova variante in arrivo: a...
Iliad lancia la sua prima offerta FWA pe...
Addio compromessi? I nuovi tablet rugged...
Cooler Master al Computex 2026: case sil...
G.Skill mostra AMD EXPO ULL al Computex:...
Hilti e i data center, l'ingegneria dell...
Narwal anticipa il Prime Day: sconti fin...
Sharkoon mantiene il rapporto qualit&agr...
Xference e Aruba insieme per l'IA privat...
Google Wallet, in arrivo i documenti d'i...
Recensione OPPO Enco Clip2: tanta tecnol...
Altro passo dei cinesi in Europa: Chery ...
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: 21:31.


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