Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
MSI FORGE GK600 TKL WIRELESS: switch lineari hot-swap, tripla connettività, display LCD e 5 strati di fonoassorbimento. Ottima in gaming, a 79,99 euro
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI porta un importante aggiornamento alla sua linea di gimbal camera tascabili con Osmo Pocket 4: sensore CMOS da 1 pollice rinnovato, gamma dinamica a 14 stop, profilo colore D-Log a 10 bit, slow motion a 4K/240fps e 107 GB di archiviazione integrata. Un prodotto pensato per i creator avanzati, ma che convince anche per l'uso quotidiano
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 11-06-2006, 21:26   #1
Manugal
Senior Member
 
L'Avatar di Manugal
 
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
[C] Visita per livelli

Ciao a tutti!

Non ho capito bene a che serve usare una coda per effettuare la visita di un albero generale per livelli. Ad esempio in questo piccolo pezzo di codice è implementata la visita per livelli (non so se è esatta):

Codice:
void visita (gtree t){
    coda q;
    gtree aux,tmp;
 
    init(q);
    if (!t) enqueue(q,t);
    while(!empty(q)){
	aux = dequeue(q);
	printf("%d",aux->dato);
	tmp = aux->lista_fratelli
	while(!aux){
		enqueue(q,aux);
		aux = aux->lista_fratelli;
	}
	if (!(aux->primo_figlio)) 
		enqueue(q,aux->primo_figlio);
    }
}
Non riesco a capire bene cosa accade nella coda ad ogni iterazione. Grazie.

Ultima modifica di Manugal : 11-06-2006 alle 21:30.
Manugal è offline   Rispondi citando il messaggio o parte di esso
Old 12-06-2006, 12:30   #2
Manugal
Senior Member
 
L'Avatar di Manugal
 
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
up
Manugal è offline   Rispondi citando il messaggio o parte di esso
Old 12-06-2006, 13:43   #3
Black imp
Senior Member
 
Iscritto dal: Nov 2000
Città: MILANO
Messaggi: 2662
senti abbi pazienza ma se non scrivi il testo di tutte quelle funzioni come si fa a immaginarsi che cosa fanno?

se sono troppo lunghe metti un allegato scaricabile con tutto. se no scrivi direttamente la definizione delle strutture dati E delle funzioni .


dopo ripasso.
Black imp è offline   Rispondi citando il messaggio o parte di esso
Old 12-06-2006, 16:08   #4
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Beh, in effetti il codice non e' per niente chiaro:
- viene valorizzata una variabile tmp che non viene usata e non si sa a cosa serva;

- L'istruzione
if (!t) enqueue(q,t);
mette un NULL nella cosa, salvo poi, con l'istruzione
aux = dequeue(q);
printf("%d",aux->dato);
estrarlo subito e dereferenziarlo. Questo dovrebbe provocare un crash, a meno che ci siano delle parti di programma non specificate che aggiustino le cose...

prova a pubblicare qualcosa di piu' e magari qualche info di cui sei a conoscenza.

High Flying
Sottovento
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 15-06-2006, 11:47   #5
Manugal
Senior Member
 
L'Avatar di Manugal
 
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
C'era solo scritto questo: "Si trattava di usare una coda per mantenere traccia del livello dei nodi. La coda poteva essere definita con un dato di tipo gtree. Assumiamo quindi un tipo coda e assumiamo date tutte le routine standard su coda." La struttura dell'albero era una cosa del genere, credo almeno. Non ricordo bene perché quel codice l'ho copiato dalle soluzioni di un esame e il testo del problema non era scritto.

Codice:
struct gtree{
   int dato;
   struct gtree *primofiglio;
   struct node *listafratelli;
}
Effettivamente alcune parti del programma non sono molto chiare (forse avrà sbagliato a trascriverle). Ad esempio come if (!t) enqueue(q,t); oppure come if (!(aux->primo_figlio)).
Manugal è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless Tastiera gaming MSI GK600 TKL: switch hot-swap, ...
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici DJI Osmo Pocket 4: la gimbal camera tascabile cr...
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
iPhone 18 Pro: il componente che garanti...
DeepL alza il livello: con Voice-to-Voic...
Apple sta utilizzando sempre più ...
Il MacBook Neo vende tanto? Microsoft le...
AST SpaceMobile BlueBird 7: Blue Origin ...
È il momento migliore per comprar...
Svendita MacBook Pro: c'è il mode...
Oggi questa TV TCL QLED da 43 pollici co...
Il caricatore multiplo da 200W che va be...
Top 7 Amazon, il meglio del meglio di qu...
Spento lo strumento LECP della sonda spa...
Voyager Technologies ha siglato un accor...
GoPro annuncia la linea MISSION 1 con tr...
Alcune varianti dei futuri Samsung Galax...
Il ridimensionamento di OnePlus in Europ...
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: 23:47.


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