Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
WF-1000X M6 è la sesta generazione di auricolare in-ear sviluppata da Sony, un prodotto che punta a coniugare facilità di utilizzo con una elevata qualità di riproduzione dei contenuti audio e una cura nella riduzione del rumore ambientale che sia da riferimento
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake ha presentato diverse novità per la sua piattaforma legate all'intelligenza artificiale. Quella forse più eclatante è una collaborazione con OpenAI, ma non mancano diverse nuove funzionalità che rendono la piattaforma più flessibile e in grado di rispondere meglio alle esigenze in continuo cambiamento delle aziende
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 24-09-2010, 11:03   #1
Negative_creep
Senior Member
 
L'Avatar di Negative_creep
 
Iscritto dal: Jul 2005
Città: Milano
Messaggi: 1078
[C] Creare un heap albero binario senza l'uso di un array

Ciao a tutti, premetto che non ho mai costruito gli alberi in C e molto probabilmente commetterò diversi errori in quello che voglio esporvi. Guardando la struttura Heap, essa (correggetemi se sbaglio) si basa solitamente su un array di dimensione n nel quale vigono le seguenti regole:

- L'elemento di A[i] >= di quello di A[2i]
- L'elemento di A[i] >= di quello di A[2i+1]
- L'elemento di A[n/2] >= di quello di A[n]

L'operazione che vorrei fare io è quella di ordinare semplicemente un albero in maniera decrescente in modo da avere ad ogni inserimento l'elemento di massima priorità nella radice o, se i figli di dx e sx sono uguali alla radice, averli comunque ad una profondità bassa rispetto all'albero, quindi disponibili subito dopo pochi confronti.
Viste le prestazioni migliori in termini di tempo per la ricerca e l'inserimento di un elemento, ho bisogno di utilizzare come struttura dati l'albero.
Per la creazione di questa struttura dati ho seguito il codice presente a questo indirizzo in fondo alla pagina http://it.wikipedia.org/wiki/Albero_binario mi funziona come albero binario, ma volevo sapere da voi che modifiche potevo apportare per rendere l'albero uno heap senza l'ausilio di un array.
__________________
CPU: AMD Phenom II X4 965 C3 Motherboard: Asrock 980DE3/U3S3 R2.0 Ram: G-Skill F3 CL7 4GB DDR3 1333Mhz Alimentatore: Corsair VX550w Hard-Disk: Samsung SSD EVO 860 500GB - WD Caviar Black 1 TB

Ultima modifica di Negative_creep : 24-09-2010 alle 11:05.
Negative_creep è offline   Rispondi citando il messaggio o parte di esso
Old 24-09-2010, 11:40   #2
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
se vuoi fare questa cosa immagino tu sappia che lo heap ha qualche proprietà in più

l'array probabilmente è la cosa migliore proprio perché una di queste è che è completo fino al penultimo livello
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 24-09-2010, 12:05   #3
Negative_creep
Senior Member
 
L'Avatar di Negative_creep
 
Iscritto dal: Jul 2005
Città: Milano
Messaggi: 1078
Il problema è che gli array andrebbero allocati con una certa dimensione, una volta esaurita dovrei riallocare lo stesso spazio in un array grande il doppio e così via...
Vorrei quindi evitare questa cosa, usando un albero come struttura dati e ordinare i nodi in base alla massima priorità, che sarà presente alla radice però non saprei come fare.
__________________
CPU: AMD Phenom II X4 965 C3 Motherboard: Asrock 980DE3/U3S3 R2.0 Ram: G-Skill F3 CL7 4GB DDR3 1333Mhz Alimentatore: Corsair VX550w Hard-Disk: Samsung SSD EVO 860 500GB - WD Caviar Black 1 TB
Negative_creep è offline   Rispondi citando il messaggio o parte di esso
Old 24-09-2010, 14:15   #4
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
forse invece di un array potresti usare una matrice "triangolare", in cui ogni riga è un array di dimensione 2^i?

in pratica la situazione rimane simile a quella delll'array, ma ogni volta puoi riallocare solo il vettore delle righe, che è di dimensione logn, cioè l'altezza dello heap, quindi ben più piccolo dell'array usuale

non so se c'è qualcosa di più complicato che ti permette di non riallocare niente, il problema è poter anche accedere a una foglia in O(1)
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 24-09-2010, 14:28   #5
Negative_creep
Senior Member
 
L'Avatar di Negative_creep
 
Iscritto dal: Jul 2005
Città: Milano
Messaggi: 1078
Ok grazie tuccio! Ci provo...
__________________
CPU: AMD Phenom II X4 965 C3 Motherboard: Asrock 980DE3/U3S3 R2.0 Ram: G-Skill F3 CL7 4GB DDR3 1333Mhz Alimentatore: Corsair VX550w Hard-Disk: Samsung SSD EVO 860 500GB - WD Caviar Black 1 TB
Negative_creep è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Meno di 3kg per 'diventare' bionici: l'u...
Al regalo di San Valentino ci pensa HUAW...
Intel multata in India: 30 milioni di do...
Beast of Reincarnation ha una data di us...
Provati Reno15 e Reno15 FS: analisi comp...
L'Europa sfida la Cina sul litio: in Fin...
Sono 32, di cui 6 nuove, le offerte Amaz...
Rinnovo dei coupon Amazon nascosti: ecco...
Corsair aggiorna la confezione delle RAM...
Ecco tutti i robot aspirapolvere in offe...
Tachyum: dal processore universale alle ...
L'eVTOL tedesco per missioni mediche e m...
Zscaler Threat Report 2026: l'adozione d...
Claude AI minaccia omicidi e ricatti qua...
Dentro la gara: a Milano Cortina 2026 i ...
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: 14:31.


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