Casa Finanza personale A Taste of Recursion - dummies

A Taste of Recursion - dummies

Video: OCAML Tutorial 13/33: A Word on Recursion and Recursive Functions 2025

Video: OCAML Tutorial 13/33: A Word on Recursion and Recursive Functions 2025
Anonim

La ricorsione è una parola grande e spaventosa che si sente spesso sulla programmazione, specialmente il tipo frustrante di programmazione che insegnano all'università. Anche se è un concetto facile da descrivere, è davvero una vera mente quando si tratta di capire come funziona la ricorsione. La maggior parte delle persone lo accetta e va avanti. Non qui!

La ricorsione è fondamentalmente il processo di una funzione che si chiama. Ad esempio:

void funct (int x) {funct (x);}

In questa porzione di codice, si vede un terribile esempio di una funzione ricorsiva, ma serve a scopi illustrativi qui: Il funct () chiama se stessa. Questa è ricorsione. Ora, ciò che accade in questo esempio è fondamentalmente un ciclo infinito e, grazie a un qualcosa di tecnico, chiamato lo stack pointe r , il computer si arresta. Ma è solo un'illustrazione.

Affinché la ricorsione funzioni, la funzione deve avere una condizione di salvataggio, proprio come un loop. Pertanto, è necessario testare il valore passato alla funzione ricorsiva o il suo valore di ritorno. Ecco un esempio migliore di una funzione ricorsiva:

void ricorsione (int x) {if (x == 0) return; else {puts ("Boop!"); ricorsione (- x);}}

La funzione ricorsione () accetta il valore x . Se x è uguale a zero, la funzione si attiva. In caso contrario, la funzione viene richiamata di nuovo, ma il valore di x viene ridotto. L'operatore del prefisso di decremento viene utilizzato in modo che il valore di x venga ridotto prima di venga effettuata la chiamata.

La funzione ricorsione di esempio () sputa fondamentalmente il testo Boop! un determinato numero di volte. Quindi se ricorsione () viene chiamato con il valore 10, si vede quel testo visualizzato dieci volte.

La parte assurda della ricorsione è che la funzione continua a chiamarsi, avvolgendosi sempre più strettamente, come se fosse in una spirale. Nell'esempio precedente, la condizione x == 1 alla fine risolve quel pasticcio complicato, ritirandosi sempre più fino a quando la funzione non viene completata.

Il seguente codice mostra un programma completo che utilizza la funzione di ricorsione () di esempio.

#include void ricorsione (int x); int main () {ricorsione (10); return (0);} void ricorsione (int x) {if (x == 0) return; else {puts ("Boop!"); ricorsione (- x);}}

Una dimostrazione comune di ricorsione è una funzione fattoriale. Il fattoriale è il risultato della moltiplicazione di un valore per ciascuno dei suoi numeri interi positivi. Ad esempio:

4! = 4 × 3 × 2 × 1

Il risultato di questo fattoriale è 24. Il computer può anche fare questo calcolo, implementando un ciclo o creando una funzione ricorsiva.Ecco una funzione del genere:

int factorial (int x) {if (x == 1) return (x); else return (x * factorial (x-1));}

Come per le altre funzioni ricorsive, la funzione factorial () contiene una condizione di uscita: x == 1. In caso contrario, la funzione viene richiamata con un valore inferiore al valore corrente di x . Ma tutte le azioni si svolgono con i valori di ritorno.

A Taste of Recursion - dummies

Scelta dell'editore

Vantaggi di base della rete - manichini

Vantaggi di base della rete - manichini

Se la verità viene detta, le reti di computer sono un problema da impostare. Perché i vantaggi di avere una rete rendono la pena di crearne uno utile. Non è necessario essere un dottorato di ricerca per comprendere i vantaggi del networking. Le reti riguardano esclusivamente la condivisione. Nello specifico, le reti riguardano la condivisione di tre elementi: informazioni, risorse, ...

Biometria L'accettazione, la privacy e la legge - manichini

Biometria L'accettazione, la privacy e la legge - manichini

La tecnologia biometrica non è affatto universalmente accettata da tutti gli utenti. Ci sono una serie di considerazioni sociali e legali che danno ad ogni organizzazione una pausa prima di fare il salto a capofitto nell'implementazione di un sistema biometrico. Le persone sono più a loro agio con i sistemi di raccolta biometrici che sono i meno intrusivi. Scanner per retina e nasi elettronici sono ...

Biometria Nozioni di base - manichini

Biometria Nozioni di base - manichini

La biometria non è roba da fantascienza. Puoi trovare una dozzina di modi più o meno efficaci per utilizzare la biometria per identificare qualcuno, ognuno dei quali si divide in due classi: la biometria fisiologica misura una parte specifica della struttura o della forma di una porzione del corpo di un soggetto. La biometria comportamentale è più interessata a come ...

Scelta dell'editore

Come creare un nuovo dizionario personalizzato in Excel 2007 - dummies

Come creare un nuovo dizionario personalizzato in Excel 2007 - dummies

In Excel 2007, è possibile creare dizionari personalizzati da utilizzare quando si esegue il controllo ortografico dei fogli di lavoro. Utilizzare il pulsante Aggiungi al dizionario nella finestra di dialogo Controllo ortografico per aggiungere parole sconosciute a un dizionario personalizzato. Per impostazione predefinita, Excel aggiunge queste parole a un file dizionario personalizzato denominato CUSTOM. DIC, ma è possibile creare una nuova personalizzazione ...

Come creare un componente aggiuntivo da un file di cartella di lavoro Excel Excel normale in VBA - modi di dire

Come creare un componente aggiuntivo da un file di cartella di lavoro Excel Excel normale in VBA - modi di dire

Sebbene sia possibile convertire qualsiasi cartella di lavoro di Excel in un componente aggiuntivo, non tutte le cartelle di lavoro traggono vantaggio da questa conversione. Una cartella di lavoro senza macro rende un componente aggiuntivo inutile. In effetti, gli unici tipi di cartelle di lavoro che traggono vantaggio dall'essere convertiti in un componente aggiuntivo sono quelli con macro. Ad esempio, una cartella di lavoro costituita da macro generiche (Sub ...

Come creare una nuova cartella di lavoro in Excel 2010 - dummy

Come creare una nuova cartella di lavoro in Excel 2010 - dummy

Se si lavora in Microsoft Excel 2010 e vuoi iniziare a lavorare in un nuovo file di cartella di lavoro di Excel, puoi facilmente creare una nuova cartella di lavoro. Per fare ciò, puoi usare un comando nella scheda File o una scorciatoia da tastiera. Fare clic sulla scheda File. Excel visualizza la visualizzazione Backstage, in cui è possibile accedere ai comandi relativi ai file. ...

Scelta dell'editore

Usa lo strumento Gomma in Adobe Illustrator CS5 - manichini

Usa lo strumento Gomma in Adobe Illustrator CS5 - manichini

Adobe Illustrator Creative Suite 5 (Adobe CS5) Illustrator è utilizzato per rimuovere rapidamente aree di grafica con la stessa facilità con cui si cancellano i pixel in Photoshop, accarezzando con il mouse su qualsiasi forma o gruppo di forme. Facendo doppio clic sullo strumento Gomma, è possibile definire il diametro, l'angolo e la rotondità della gomma. Se stai usando un ...

Trasforma gli strumenti in Adobe Illustrator CS5 - dummies

Trasforma gli strumenti in Adobe Illustrator CS5 - dummies

I più popolari strumenti di trasformazione in Adobe Creative Suite 5 (Adobe CS5) Illustrator - Rifletti, scala, inclina, rimodella e Trasformazione libera: sono facili da usare e modificano rapidamente la tua illustrazione. Lo strumento Rifletti Niente è simmetrico, giusto? Forse no, ma gli oggetti non creati simmetricamente in Illustrator possono sembrare off-kilter. Utilizzando lo strumento Rifletti, si ...

Quando utilizzare Adobe CS5 Illustrator - dummies

Quando utilizzare Adobe CS5 Illustrator - dummies

Utilizzando Adobe Creative Suite 5 (Adobe CS5) Illustrator anziché Photoshop , ottieni diversi benefici. Potresti aver sentito che Illustrator è migliore per la grafica vettoriale, ma perché e che altro porta? Illustrator può salvare ed esportare immagini nella maggior parte dei formati di file. Scegliendo di salvare o esportare, è possibile creare un ...