Torna indietro   Hardware Upgrade Forum > Software > Programmazione

OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum
Abbiamo partecipato all'OVHcloud Summit 2025, conferenza annuale in cui l'azienda francese presenta le sue ultime novità. Abbiamo parlato di cloud pubblico e privato, d'intelligenza artificiale, di computer quantistici e di sovranità. Che forse, però, dovremmo chiamare solo "sicurezza"
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a
Abbiamo potuto mettere le mani in anteprima sul nuovo monitor MSI dedicato ai giocatori: un mostro che adotta un pannello QD-OLED da 26,5 pollici con risoluzione 2560 x 1440 pixel, frequenza di aggiornamento fino a 500 Hz e tempo di risposta di 0,03 ms GtG
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro
DJI aggiorna la sua linea di droni ultraleggeri con Neo 2, un quadricottero da 160 grammi che mantiene la compattezza del predecessore ma introduce una stabilizzazione meccanica a due assi, sensori omnidirezionali e un sistema LiDAR
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 19-11-2010, 15:00   #1
Negative_creep
Senior Member
 
L'Avatar di Negative_creep
 
Iscritto dal: Jul 2005
Città: Milano
Messaggi: 1078
[C] Info su struttura dati Heap

Ciao a tutti, vi scrivo per avere un'informazione sugli heap. Avrei bisogno di salvare diversi dati in una struttura che mi consenta di poter costruire un albero binario partendo proprio dallo heap.
Tutti gli esempi che ho trovato usano un vettore "heap ordinato" in cui ogni elemento in posizione a[i]>=a[2i] e a[i]>=a[2i+1] da qui quindi è possibile costruire l'albero binario. Però, se ho bisogno di inserire,togliere elementi dinamicamente, il vettore non va bene come struttura di appoggio per l'heap, oppure mi sbaglio?
Anche se creassi un vettore di interi allocato dinamicamente, supponiamo

int* num=(int*)malloc(300*sizeof(int));

come farei a sapere quanti elementi ho all'interno in ogni momento?
Gli esempi sugli heap che ho trovato,usano un vettore che già contiene tutti gli elementi, e poi si procede quindi all'operazione di spostamento dei dati in modo da poterli ordinare correttamente, ma se io ho bisogno di aggiungere dinamicamente dei dati cosa utilizzo?
__________________
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 19-11-2010, 15:33   #2
Supdario
Member
 
Iscritto dal: Mar 2008
Messaggi: 267
La cosa più semplice che puoi fare è sostituire il vettore di int con una struttura che contiene sia il vettore che la quantità di elementi.

Esempio veloce (non testato):

Codice:
typedef struct {
	int *num = NULL;
	size_t size = 0;
} vector;

void ridimensiona(vector *x, size_t dimensione)
{
	(*x).num = (vector *) realloc((*x).num, sizeof(int) * dimensione);
	(*x).size = dimensione;
}

void aggiungi(vector *x, int valore);
{
	ridimensiona(&(*x), (*x).size+1);
	(*x).num[size-1] = valore; 
}

int main()
{
	//[...]
	vector albero;
	aggiungi(&albero, 10);
	printf("Il primo elemento è %d e la dimensione è %d", albero.num[0], albero.size);
	//[...]
	return 0;
}
Questo dovrebbe mostrare "10" e "1", ma non so se funziona.

In ogni caso se hai la possibilità di usare il C++ i std::vector ti alleggerirebbero il lavoro di molto.

Ultima modifica di Supdario : 19-11-2010 alle 15:36.
Supdario è offline   Rispondi citando il messaggio o parte di esso
Old 19-11-2010, 17:09   #3
Negative_creep
Senior Member
 
L'Avatar di Negative_creep
 
Iscritto dal: Jul 2005
Città: Milano
Messaggi: 1078
Non posso, devo usare C. Ma se usassi le liste anzichè il vettore?
__________________
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 19-11-2010, 17:16   #4
goldorak
Senior Member
 
Iscritto dal: Apr 2003
Messaggi: 16462
Quote:
Originariamente inviato da Negative_creep Guarda i messaggi
Ciao a tutti, vi scrivo per avere un'informazione sugli heap. Avrei bisogno di salvare diversi dati in una struttura che mi consenta di poter costruire un albero binario partendo proprio dallo heap.
Tutti gli esempi che ho trovato usano un vettore "heap ordinato" in cui ogni elemento in posizione a[i]>=a[2i] e a[i]>=a[2i+1] da qui quindi è possibile costruire l'albero binario. Però, se ho bisogno di inserire,togliere elementi dinamicamente, il vettore non va bene come struttura di appoggio per l'heap, oppure mi sbaglio?
Anche se creassi un vettore di interi allocato dinamicamente, supponiamo

int* num=(int*)malloc(300*sizeof(int));

come farei a sapere quanti elementi ho all'interno in ogni momento?
Gli esempi sugli heap che ho trovato,usano un vettore che già contiene tutti gli elementi, e poi si procede quindi all'operazione di spostamento dei dati in modo da poterli ordinare correttamente, ma se io ho bisogno di aggiungere dinamicamente dei dati cosa utilizzo?
Ti serve uno heap binomiale.
Dai un occhiata all'articolo su wikipedia : http://en.wikipedia.org/wiki/Binomial_heap.
__________________
MICROSOFT : Violating your privacy is our priority
goldorak è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2010, 16:25   #5
Negative_creep
Senior Member
 
L'Avatar di Negative_creep
 
Iscritto dal: Jul 2005
Città: Milano
Messaggi: 1078
Ok grazie, gli darò un'occhiata appena posso. Non sapevo neanche che esistessero!
__________________
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


OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum OVHcloud Summit 2025: le novità del cloud...
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI C...
DJI Neo 2 in prova: il drone da 160 grammi guadagna il gimbal e molto altro DJI Neo 2 in prova: il drone da 160 grammi guada...
L'IA "seria" di Appian è diversa: inserita nei processi e rispetta dati e persone L'IA "seria" di Appian è divers...
Polestar 3 Performance, test drive: comodità e potenza possono convivere Polestar 3 Performance, test drive: comodit&agra...
Super ribassi Bose su Amazon: QuietComfo...
Instagram cambia rotta: basta lavoro ibr...
AirPods Pro 3 a prezzo bomba, ma le AirP...
Prezzi giù su Oral-B: spazzolini elettri...
Europol ha smantellato Cryptomixer: sequ...
Roborock H60 Hub: aspira e si svuota da ...
Xiaomi fa sul serio anche sulle auto: su...
NVIDIA in prima fila per il processo a 1...
Samsung Galaxy Z TriFold: il primo smart...
Windows 11 è un disastro: ha biso...
BYD domina in Italia tra le elettriche: ...
Li abbiamo scovati nel catalogo Amazon: ...
Samsung Galaxy S26: la ricarica wireless...
Quale sarà il prezzo della Steam ...
Xiaomi 17 Ultra è sempre pi&ugrav...
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: 11:08.


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