Torna indietro   Hardware Upgrade Forum > Software > Programmazione

HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
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 ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70 porta il concetto di smartphone ultrasottile su un terreno più concreto e accessibile: abbina uno spessore sotto i 6 mm a una batteria di capacità relativamente elevata, un display pOLED da 6,7 pollici e un comparto fotografico triplo da 50 MP. Non punta ai record di potenza, ma si configura come alternativa più pragmatica rispetto ai modelli sottili più costosi di Samsung e Apple
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 16-06-2011, 12:56   #1
<Gabrik>
Senior Member
 
L'Avatar di <Gabrik>
 
Iscritto dal: Apr 2006
Città: Ilê-de-France
Messaggi: 319
[C] deallocazione di un albero binario

Salve ragazzi, ho un piccolo problema, non riesco a capire come deallocare tutti i nodi di un albero
mi spiego meglio ho un albero binario, e alla chiusura del programma lo devo deallocare, quindi io ho pensato di fare una funzione ricorsiva che a partire da ogni nodo dealloca prima quelli alla sinistra, poi quelli alla destra e infine il nodo, ma pare non funzionare perché in esecuzione mi ritorna
Codice:
albero(302) malloc: *** error for object 0x1001000a8: pointer being freed was not allocated
*** set a breakpoint in malloc_error_break to debug
Dealloco...Abort trap


l'albero è strutturato con in questo modo
Codice:
typedef struct nodoABR
{
	tipobaseABR info; /* tipo di informazioni contenute nel nodo*/
	struct nodoABR *leftchild,*rightchild;
} *abr;
e la funzione che dealloca
Codice:
void DeallocaABR(abr *p)
{
	if(EmptyABR(*p)) /* se il nodo non ha figli lo dealloco direttamente */
		free(p);
	else /* altrimenti vado a sinistra poi a destra e infine lo dealloco */
	{
		DeallocaABR(&(*p)->leftchild);
		DeallocaABR(&(*p)->rightchild);
                free(p);
	}
}
idee?? è una giornata che all'uni mi sbatto su sto codice ma non riesco a cavarne niente
__________________
There is no cloud, it's just someone else computer

Ultima modifica di <Gabrik> : 16-06-2011 alle 12:58.
<Gabrik> è offline   Rispondi citando il messaggio o parte di esso
Old 16-06-2011, 13:23   #2
krivo
Junior Member
 
Iscritto dal: Oct 2010
Messaggi: 16
penso che il problema risieda nel fatto che tu disallocando un nodo qualsiasi(e i suoi figli) quando vai a disallocare il padre, riprovi a disallocare anche il figlio e questo ti dà errore
infatti dice errore: il puntatore che si sta deallocando (freed) non è allocato, perchè lo potresti aver deallocato poco prima!
una soluzione potrebbe essere per ogni nodo deallocare i figli ma non il nodo stesso, tranne che per la radice, magari introducendo un puntatore al nodo padre o una variabile su cui controlli che il nodo sia radice o meno
krivo è offline   Rispondi citando il messaggio o parte di esso
Old 16-06-2011, 13:29   #3
clockover
Senior Member
 
L'Avatar di clockover
 
Iscritto dal: Oct 2004
Messaggi: 1945
prova una soluzione del genere

Codice:
dealloca_albero(nodo n){
    if n == NULL return;
    nodo *l = n->left
    nodo *r = n->right
    free(n)
    if(l != NULL) dealloca_albero(l)
    if(r != NULL) dealloca_albero(r)
}
il controllo all'inizio potrebbe anche non servire se sei sicuro che la radice non è NULL, ma meglio mettercelo

edit:
volendo infatti potresti omettere i controlli tipo if l != NULL e r != NULL dato che appena richiamata ricorsivamente la funzione effettua il controllo, ma in termini di prestazioni è molto meno costoso un controllo che una chiamata ricorsiva

Ultima modifica di clockover : 16-06-2011 alle 13:36.
clockover è offline   Rispondi citando il messaggio o parte di esso
Old 16-06-2011, 13:36   #4
<Gabrik>
Senior Member
 
L'Avatar di <Gabrik>
 
Iscritto dal: Apr 2006
Città: Ilê-de-France
Messaggi: 319
Quote:
Originariamente inviato da krivo Guarda i messaggi
penso che il problema risieda nel fatto che tu disallocando un nodo qualsiasi(e i suoi figli) quando vai a disallocare il padre, riprovi a disallocare anche il figlio e questo ti dà errore
infatti dice errore: il puntatore che si sta deallocando (freed) non è allocato, perchè lo potresti aver deallocato poco prima!
ci avevo pensato anche io ma poi mi sono detto se prima vado nei figli e solo dopo faccio la free() perché fà così

il bello è che dà problemi anche se l'albero è formato dalla sola radice

Quote:
Originariamente inviato da krivo Guarda i messaggi
una soluzione potrebbe essere per ogni nodo deallocare i figli ma non il nodo stesso, tranne che per la radice, magari introducendo un puntatore al nodo padre o una variabile su cui controlli che il nodo sia radice o meno
se faccio un puntatore al padre il proff mi uccide appena legge il codice,
comunque lui prende *p sempre come se fosse una radice, controlla se ha figli e poi fà quello che deve fare, piuttosto credo di aver fatto casino sui puntatori quando faccio &(*p)->leftchild e &(*p)->rightchild
__________________
There is no cloud, it's just someone else computer
<Gabrik> è offline   Rispondi citando il messaggio o parte di esso
Old 16-06-2011, 13:39   #5
<Gabrik>
Senior Member
 
L'Avatar di <Gabrik>
 
Iscritto dal: Apr 2006
Città: Ilê-de-France
Messaggi: 319
Quote:
Originariamente inviato da clockover Guarda i messaggi
prova una soluzione del genere

Codice:
dealloca_albero(nodo n){
    if n == NULL return;
    nodo *l = n->left
    nodo *r = n->right
    free(n)
    if(l != NULL) dealloca_albero(l)
    if(r != NULL) dealloca_albero(r)
}
il controllo all'inizio potrebbe anche non servire se sei sicuro che la radice non è NULL, ma meglio mettercelo

edit:
volendo infatti potresti omettere i controlli tipo if l != NULL e r != NULL dato che appena richiamata ricorsivamente la funzione effettua il controllo, ma in termini di prestazioni è molto meno costoso un controllo che una chiamata ricorsiva
ok ci provo e vi faccio sapere

edit: funzia grazie adesso devo capire cosa ha che non và la mia soluzione, anche se credo e sono convinto di aver fatto casino con i puntatori a left e right

edit2: confermo avevo fatto casino con i puntatori infatti modificando la funzione così

Codice:
void DeallocaABR(abr a)
{
	if(EmptyABR(a))
		free(a);
	else
	{
		DeallocaABR(a->leftchild);
		DeallocaABR(a->rightchild);
		free(a);
	}
}
funziona grazie a tutti
__________________
There is no cloud, it's just someone else computer

Ultima modifica di <Gabrik> : 16-06-2011 alle 13:54.
<Gabrik> è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
Il primo SUV R2 di Rivian esce dalla cat...
Auricolari Bluetooth a rischio: la falla...
Modificare il nuovo indirizzo Gmail è fi...
TV 4K in offerta su Amazon: QLED Hisense...
Tesla ha ora la sua raffineria di litio:...
Ancora aumenti per Fastweb: nuove condiz...
GeForce RTX 5070 Ti: intervengono ASUS e...
Xiaomi Redmi Note 15 Pro subito giù di p...
SiFive adotta NVLink Fusion: RISC-V si i...
Amazon ha annunciato la fine di New Worl...
Umidità addio: deumidificatori el...
Konami festeggia 950 milioni di download...
Modelli gen AI sul tuo Raspberry Pi? Con...
Il CEO di Nothing, Carl Pei, avverte: i ...
Serie A, richieste di risarcimento agli ...
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:59.


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