Torna indietro   Hardware Upgrade Forum > Software > Programmazione

ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm
ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm
ASUS e HIFIMAN uniscono le forze per creare ROG Kithara, cuffie gaming con driver magnetici planari da 100mm, design open-back e microfono MEMS full-band. Una proposta che ambisce a coniugare fedeltà per audiofili e performance ludiche, disponibili a 319 euro
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 18-02-2008, 13:54   #1
Hall999
Senior Member
 
Iscritto dal: Feb 2003
Messaggi: 3571
ricorsione

Sapete dove posso trovare un testo che spieghi in modo chiaro e sintetico che mi permetta di usare con sufficienza la ricorsione nel giro di un pomeriggio?, ad oggi non riesco a implementare con naturalezza funzioni ricorsive, mi viene naturale risolvere un determinato problema in modo sequenziale.
Hall999 è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2008, 14:41   #2
Manbearpig
Member
 
L'Avatar di Manbearpig
 
Iscritto dal: Jan 2008
Messaggi: 90
Un' esempio:
Hai un albero genealogico di una famiglia, per semplificare ammettiamo che vi sia inserito solo un genitore e un solo figlio per genitore. Vuoi trovare tutti gli antenati di un figlio come fai?

funzione_antenati(nome_figlio)
{
//trova nome del genitore relativo al figlio
nome_genitore = nome_figlio->genitore;
//richiama ricorsivamente la funzione
funzione_antenati(nome_genitore)
}

alla prima iterazione troverai il padre, alla seconda il nonno, alla terza il bisnonno ecc...
Manbearpig è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2008, 14:47   #3
Manbearpig
Member
 
L'Avatar di Manbearpig
 
Iscritto dal: Jan 2008
Messaggi: 90
http://it.wikipedia.org/wiki/Ricorsione
Manbearpig è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2008, 14:59   #4
Hall999
Senior Member
 
Iscritto dal: Feb 2003
Messaggi: 3571
Il problema è che vedendo esercizi già svolti capisco benissimo il suo funzionamento, la mia difficoltà è quando la devo implementare in un esercizio e non ci riesco, ecco un esempio:

Scrivere una funzione ricorsiva che dato un array A di n numeri interi ed un numero intero x restituisce il numero di elementi di A che sono maggiori di x. Ad esempio se A vale (1,6,3,7,8) e x=5 la funzione deve restituire 3, perchè ci sono 3 elementi maggiori di 5.
Scrivere quindi il main che richiama la funzione leggendone gli argomenti da tastiera (o impostandoli da programma) e visualizzandone i risultati sullo schermo.
Hall999 è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2008, 15:29   #5
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Io per la ricorsione ho sempre ragionato in modo molto simile alle dimostrazioni per induzione.

Prima di tutto scrivo la condizione di arresto: cioè quando la mia funzione deve terminare la ricorsione.

Ad esempio nel caso in cui i dati su cui si lavorano è un vettore, la condizione di arresto è quando sono arrivato all'ultimo elemento del vettore o non ci sono elementi su cui lavorare.

Poi scrivo la condizione di funzionamento generica, cioè mi dimentico di tutto quello che c'è d'interno e mi metto in un caso di funzionamento in cui ho ha disposizione dati e devo lavorare su un generico elemento.

Ragionando sempre su un vettore, mi riferisco al caso in cui sia nel mezzo al vettore.

Semplicemente scrivo cosa dovrei fare con quel dato elemento e metto in relazione l'elemento con i risultati che mi ritorna la ricorsione (o le ricorsioni). Senza pensare alle condizioni limite, ma solo al funzionamento a regime, al resto ci pensa la condizione di arresto.

Generalmente isolando i due problemi le cose vengono molto naturali e permettono di risolvere esercizi sulle ricorsioni in maniera molto "naturale".
cionci è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm ASUS ROG Kithara: quando HIFIMAN incontra il gam...
Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Anthropic rifiuta l'ultimatum del Pentag...
Il Governo Trump ordina ai diplomatici d...
Questo computer portatile per giocare è ...
Tesla Model Y a 7 posti disponibile anch...
Scope elettriche potenti che lavano e as...
eBay annuncia numerosi licenziamenti dop...
Robot aspirapolvere a prezzi mai visti: ...
AMD RDNA 5 'AT0': possibile Radeon gamin...
Roborock F25 Ace Pro: la scopa lavapavim...
HP OmniBook Ultra in sconto flash: AMD R...
DJI sfida la FCC: vuole annullare il ban...
Un'altra rimodulazione da Fastweb: rinca...
Nacon è in crisi: il publisher ha...
Colpo di scena a Hollywood: Netflix si s...
AMD Ryzen AI 400 su desktop: NPU da 60 T...
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: 10:21.


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