Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Per diversi giorni il Galaxy S26 Ultra di Samsung è stato il nostro compagno di vita. Oltre alle conferme del colosso coreano come la qualità del display e una suite AI senza rivali, arriva il Privacy Display, un unicum nel mondo smartphone. Ci sono ancora alcuni gap che non sono riusciti a colmare lato batteria e fotocamera, seppur con alcuni miglioramenti.
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Abbiamo provato per voi il nuovo DLC lanciato a sorpresa da Blizzard per Diablo II: Resurrected e quella che segue è una disamina dei nuovi contenuti che abbiamo avuto modo di sperimentare nel corso delle nostre sessioni di gioco, con particolare riguardo per la nuova classe dello Stregone
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Siamo tornati nel parco tecnologico di Trieste per il kick-off del programma che mette a disposizione di cinque startup le infrastrutture di ricerca, dal sincrotrone Elettra ai laboratori di genomica e HPC. Roberto Pillon racconta il modello e la visione
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 17-08-2003, 13:31   #1
noodles
Member
 
L'Avatar di noodles
 
Iscritto dal: May 2003
Città: Umbria
Messaggi: 220
[C] Torri di Hanoi

Sto impazzendo ; allora devo creare una funzione ricorsiva che prende in input il numero di dischi, la torre di partenza, quella di appoggio e quella di arrivo. Questa funzione deve stampare le mosse per risolvere il problema delle torri...
Le funzioni ricorsive le ha capite abbastanza, ma ho capito quelle che restituiscono un numero (per esempio il fattoriale di un numero), ma questa proprio non ci arrivo.
Allora supponiamo di avere una torre con 3 dischi nel primo palo, che devono essere spostati nel terzo palo:
hanoi(3)
richiamo hanoi(2) e in seguito stampo(1 --> 3, cioè sposto il terzo disco dal primo palo al terzo)
hanoi(2)
richiamo hanoi(1) e in seguito stampo(1 --> 2)
hanoi(1) stampa(1 --> 3)

piu' o meno la ricorsione dovrebbe essere cosi'??

Mi ci fate arrivare in qualche modo???






Sto impazzendo di giorno in giorno (se uno si sforza troppo si rischia di impazzire??? )


grazie
__________________
gli hackers non esistono
noodles è offline   Rispondi citando il messaggio o parte di esso
Old 17-08-2003, 19:10   #2
noodles
Member
 
L'Avatar di noodles
 
Iscritto dal: May 2003
Città: Umbria
Messaggi: 220
quando mi ricapita di avere a che fare con le funzioni ricorsive, è meglio partire dall'"alto" o dal "basso"?? Analizzo prima il caso di base???



grazie
__________________
gli hackers non esistono
noodles è offline   Rispondi citando il messaggio o parte di esso
Old 17-08-2003, 19:41   #3
recoil
Senior Member
 
L'Avatar di recoil
 
Iscritto dal: Jul 2002
Città: Milano
Messaggi: 19149
se vuoi un consiglio il modo migliore per capire come funziona la ricorsione è vederla in assembly oppure studiarsi per bene come funzionano il record di attivazione delle funzioni e lo stack.

se il tuo problema invece è capire quando o come usare una funzione ricorsiva allora non saprei come dirti. per me la ricorsione spesso è la soluzione più intuitiva mentre è più complesso il ragionamento per arrivare ad una soluzione iterativa.
recoil è offline   Rispondi citando il messaggio o parte di esso
Old 19-08-2003, 20:18   #4
noodles
Member
 
L'Avatar di noodles
 
Iscritto dal: May 2003
Città: Umbria
Messaggi: 220
nessuno sa darmi una mano???
__________________
gli hackers non esistono
noodles è offline   Rispondi citando il messaggio o parte di esso
Old 20-08-2003, 11:13   #5
goldorak
Senior Member
 
Iscritto dal: Apr 2003
Messaggi: 16462
Ciao, la soluzione e' abbastanza semplice. Supponi di spostare n ( n >=1) dischi dal piolo a al piolo c utilizzando il piolo b come piolo ausiliario. Sia Hanoi(n,a,b,c) la funzione che ti stampa l'elenco delle mosse da fare. Inanzitutto devi identificare il caso base ed il caso passo. Il caso base consiste nel spostare 1 disco dal piolo a al piolo c quindi basta stampare a->c. Per il caso passo invece devi spostare n dischi dal piolo a al piolo c. Quindi prima sposti n-1 dischi dal piolo a al piolo b utilizzando il piolo c come piolo ausiliario. Poi ti rimane 1 disco da spostare dal piolo a al piolo c. Come ultimo passo sposti gli n-1 dischi dal piolo b al piolo c utilizzando il piolo a come piolo ausiliario. In pseudo codice la funzione e'

Codice:
Hanoi(n,a,b,c) { //sposta n dischi dal piolo a al piolo c tramite il piolo b
 if n=1 then stampa a->c
 else { Hanoi(n-1,a,c,b)
            stampo a->c
           Hanoi(n-1,b,a,c)}
}

Ultima modifica di goldorak : 20-08-2003 alle 11:39.
goldorak è offline   Rispondi citando il messaggio o parte di esso
Old 21-08-2003, 20:30   #6
noodles
Member
 
L'Avatar di noodles
 
Iscritto dal: May 2003
Città: Umbria
Messaggi: 220
Capito. Grazie mille
__________________
gli hackers non esistono
noodles è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
Diablo II Resurrected: il nuovo DLC Reign of the Warlock Diablo II Resurrected: il nuovo DLC Reign of the...
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup Deep Tech Revolution: così Area Science P...
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo HP OMEN MAX 16 con RTX 5080: potenza da desktop ...
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta Recensione Google Pixel 10a, si migliora poco ma...
Spotify introduce 'Taste Profile': il co...
Sole e pioggia insieme: il nuovo pannell...
AWS e Cerebras uniscono le forze: nuova ...
Windows 11: accesso al drive C: bloccato...
BYD pronta a comprare un marchio storico...
Windows 11 si prepara ai monitor oltre i...
Apple avrebbe fissato un target di vendi...
Ultimi giorni per sfruttare le Offerte d...
I migliori smartphone in offerta ora su ...
Le migliori TV delle Offerte di Primaver...
Uno dei robot più avanzati del 2025 crol...
Robot aspirapolvere con stazione automat...
Il nuovo top di gamma compatto di OPPO n...
Nilox aggiorna la sua gamma di fat e-bik...
Meta valuta tagli fino al 20% della forz...
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: 05:25.


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