Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Al .NEXT 2026 di Chicago, Nutanix ha mostrato quanto sia cambiata: una piattaforma software che gestisce VM, container e carichi di lavoro IA ovunque, dall’on-premise al cloud pubblico. Con un’esecuzione rapidissima sulle partnership e sulla migrazione da VMware
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 22-04-2014, 21:14   #1
DomusP45
Senior Member
 
L'Avatar di DomusP45
 
Iscritto dal: Apr 2010
Città: Whiterun
Messaggi: 580
[C++] Trasformare una funzione ricorsiva in qualcos'altro?

Salve a tutti.

Qualcuno sa dirmi come posso trasformare una funzione ricorsiva in una funzione non ricorsiva?

Chiedo questa cosa perchè vorrei avere una funzione non ricorsiva che si occupi di scansionare un vector di elementi, multilivello.

Il codice attuale è questo:

Codice:
void addraw(cubo temp)
{
	//se non ci sono sottocubi
	if (temp.lista_sottocubi.size() == 0)
	{		
			if (temp.livello == LMAXI) {
				 double centro[3]={(temp.V[6].x)/2, (temp.V[6].y)/2,(temp.V[6].z)/2};
				 //salvataggio centro e lato
			}
	}
//se i sottocubi ci sono
else {
		for (int i=0;i<(int)temp.lista_sottocubi.size();i++){
				addraw(temp.lista_sottocubi[i]);
			}
	 }
}
come si passa da una ricorsiva ad una ad esempio iterativa?
__________________
Come la chiami la chiami, la cocozza sempre cocozza è.
DomusP45 è offline   Rispondi citando il messaggio o parte di esso
Old 22-04-2014, 21:28   #2
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Risposta banale: usando uno stack per tenere traccia degli elementi intermedi che ti servono.

Poi magari possono esserci soluzioni migliori (più efficientii) in base all'algoritmo da implementare. Vedi la classica implementazione del fattoriale, ad esempio.

Comunque io preferisco nettamente l'eleganza tipica delle soluzioni ricorsive.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 22-04-2014, 21:49   #3
DomusP45
Senior Member
 
L'Avatar di DomusP45
 
Iscritto dal: Apr 2010
Città: Whiterun
Messaggi: 580
Quote:
Originariamente inviato da cdimauro Guarda i messaggi
Risposta banale: usando uno stack per tenere traccia degli elementi intermedi che ti servono.

Poi magari possono esserci soluzioni migliori (più efficientii) in base all'algoritmo da implementare. Vedi la classica implementazione del fattoriale, ad esempio.

Comunque io preferisco nettamente l'eleganza tipica delle soluzioni ricorsive.
ed io sono daccordo con te...ma a quanto pare sono poco efficaci le funzioni ricorsive.

A me mi crea problemi per disegnare il contenuto di quell'oggetto con OpenGL, e quindi volevo provare usando una funzione non ricorsiva...
__________________
Come la chiami la chiami, la cocozza sempre cocozza è.
DomusP45 è offline   Rispondi citando il messaggio o parte di esso
Old 23-04-2014, 05:32   #4
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Prova con uno stack allora, ma guardando il codice mi sorge il dubbio che la funzione che hai scritto sia inefficiente perché non passi un puntatore o reference (meglio!) all'oggetto (o struttura) cubo, ma ogni volta ne fai una copia intera. Per cui non risolveresti molto passando a una funzione non ricorsiva.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 23-04-2014, 07:16   #5
DomusP45
Senior Member
 
L'Avatar di DomusP45
 
Iscritto dal: Apr 2010
Città: Whiterun
Messaggi: 580
Quote:
Originariamente inviato da cdimauro Guarda i messaggi
Prova con uno stack allora, ma guardando il codice mi sorge il dubbio che la funzione che hai scritto sia inefficiente perché non passi un puntatore o reference (meglio!) all'oggetto (o struttura) cubo, ma ogni volta ne fai una copia intera. Per cui non risolveresti molto passando a una funzione non ricorsiva.
Cosa mi consigli di fare allora? Di modificare questa? Come?

Ti ringrazio anticipatamente per la disponibilità
__________________
Come la chiami la chiami, la cocozza sempre cocozza è.
DomusP45 è offline   Rispondi citando il messaggio o parte di esso
Old 23-04-2014, 07:32   #6
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
Come ti è suggerito dovresti passare alla funzione il puntatore invece dell'intera struttura, la firma della funzione diventerebbe questa:
void addraw(cubo *temp)
Naturalmente per accedere ai campi di temp dovrai usare l'operatore -> invece del punto.
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 23-04-2014, 07:47   #7
DomusP45
Senior Member
 
L'Avatar di DomusP45
 
Iscritto dal: Apr 2010
Città: Whiterun
Messaggi: 580
Quote:
Originariamente inviato da Daniels118 Guarda i messaggi
Come ti è suggerito dovresti passare alla funzione il puntatore invece dell'intera struttura, la firma della funzione diventerebbe questa:
void addraw(cubo *temp)
Naturalmente per accedere ai campi di temp dovrai usare l'operatore -> invece del punto.
Ok,
la domanda è: questo tipo di riferimento, cambia le performance della funzione? Oppure in pratica, non cambia niente?

Mi rendo conto che non creare una copia, ma passare il puntatore al riferimento, ottimizza l'uso della memoria, ma i tempi di "calcolo" secondo voi sono migliori?
__________________
Come la chiami la chiami, la cocozza sempre cocozza è.
DomusP45 è offline   Rispondi citando il messaggio o parte di esso
Old 23-04-2014, 17:50   #8
Daniels118
Senior Member
 
L'Avatar di Daniels118
 
Iscritto dal: Jan 2014
Messaggi: 852
Oltre a ridurre la quantità di memoria utilizzata elimini anche il tempo necessario per copiare le strutture; d'altra parte si introduce un leggero ritardo nell'accesso ai campi poiché i puntatori vanno dereferenziati, però i compilatori creano codice ottimizzato per ridurre al minimo queste operazioni, in sostanza dovresti apprezzare un incremento significativo delle prestazioni.

Una soluzione iterativa sarebbe comunque più efficiente, ma richiederebbe un maggiore sforzo nella progettazione.
Daniels118 è offline   Rispondi citando il messaggio o parte di esso
Old 23-04-2014, 18:16   #9
DomusP45
Senior Member
 
L'Avatar di DomusP45
 
Iscritto dal: Apr 2010
Città: Whiterun
Messaggi: 580
Quote:
Originariamente inviato da Daniels118 Guarda i messaggi
Oltre a ridurre la quantità di memoria utilizzata elimini anche il tempo necessario per copiare le strutture; d'altra parte si introduce un leggero ritardo nell'accesso ai campi poiché i puntatori vanno dereferenziati, però i compilatori creano codice ottimizzato per ridurre al minimo queste operazioni, in sostanza dovresti apprezzare un incremento significativo delle prestazioni.

Una soluzione iterativa sarebbe comunque più efficiente, ma richiederebbe un maggiore sforzo nella progettazione.
grazie davvero
__________________
Come la chiami la chiami, la cocozza sempre cocozza è.
DomusP45 è offline   Rispondi citando il messaggio o parte di esso
Old 24-04-2014, 06:26   #10
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Visto che usi il C++, utilizza i reference (& al posto di * nella firma della funzione), che è meglio. In questo modo puoi continuare a usare anche il . anziché -> per accedere ai campi della struttura.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 05-05-2014, 09:25   #11
DomusP45
Senior Member
 
L'Avatar di DomusP45
 
Iscritto dal: Apr 2010
Città: Whiterun
Messaggi: 580
Perfetto, grazie a tutti.
__________________
Come la chiami la chiami, la cocozza sempre cocozza è.
DomusP45 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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...
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
Ryzen 7 5800X3D pronto a tornare sul mer...
NASA: l'amministrazione Trump prosegue s...
L'Iran avrebbe acquistato un satellite p...
VivaTech compie dieci anni e raddoppia p...
Le vendite di CPU si sono ridotte di 25 ...
Starship: SpaceX ha completato lo static...
Huawei FusionSolar Roadshow 2026: l'inno...
Nuovo trailer per Street Fighter: un fil...
Sovranità sui dati: arriva la pri...
Schede video NVIDIA e AMD di nuovo su Ma...
Robot aspirapolvere, TV OLED, iPhone 17 ...
EUREKA J15 Pro Ultra super interessante ...
Intel porta l'AI nei notebook entry-leve...
6000 mAh, 5G e 108MP a meno di 200€: ecc...
FRITZ!Mesh Set 2700: Wi-Fi 7 in tutta la...
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: 18:56.


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