DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
La Ricorsione
Marco D. Santambrogio – [email protected]
Ver. aggiornata al 18 Maggio 2016
C-hackathon
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
2
C-hackathon
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• 21 Giugno @ 12pm – 5pm
• 28 Giugno @ 12pm – 5pm
• 18 Luglio @ 8am -pm
http://tinyurl.com/chackathon
3
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
4
C-hackathon
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• 21 Giugno @ 12pm – 5pm
• 28 Giugno @ 12pm – 5pm
• 18 Luglio @ 8am -pm
http://tinyurl.com/chackathon
5
Riscaldiamoci subito un po’…
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
6
Riscaldiamoci subito un po’…
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
7
Obiettivi
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
•
•
•
•
Induzione matematica
Iterazione
Cosa significa “ricorsivo”
Iterazione Vs ricorsione
8
Il tacchino induttivista
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• Un tacchino induttivista viene allevato in una
fattoria del Maine (USA)
• Ogni giorno alle 7am Mr Jones porta il cibo al
tacchino induttivista
• Il tacchino segue il seguente ragionamento:
 Il giorno 1 Mr Jones mi ha portato il cibo @ 7am
 Ieri era il giorno “n” e Mr Jones mi ha portato il
cibo @ 7am
 Oggi è il giorno “n+1” ed il cibo è arrivato
 Tutti i giorni @l 7am Mr Jones mi porterà il cibo
• … Thanksgiving
9
L’induzione matematica
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• Si usa nelle definizioni e nelle dimostrazioni
10
L’induzione matematica
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• Si usa nelle definizioni e nelle dimostrazioni
• Definizione: numeri pari
 1) 0 è un numero pari
 2) se n è un numero pari anche n+2 è un numero pari
11
L’induzione matematica
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• Si usa nelle definizioni e nelle dimostrazioni
• Definizione: numeri pari
 1) 0 è un numero pari
 2) se n è un numero pari anche n+2 è un numero pari
• Dimostrazione: dimostro che (2n)2=4n2
(distributività della potenza di 2 risp. alla moltiplicazione)
 1) n=1 : vero
 2) suppongo sia vero per k, lo dimostro per k+1:
(2(k+1))2=(2k+2)2=(2k)2+8k+4= (per hp di induzione) 4k2 +8k+4 =
4(k2 +2k+1) = 4(k+1)2
 1) è il passo base, 2) è il passo di induzione
12
Iterazione e ricorsione
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• Sono i due concetti informatici che
nascono dal concetto di induzione
13
Iterazione
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• L’iterazione si realizza mediante la
tecnica del ciclo
• Il calcolo del fattoriale:
 0!=1
 n!=n(n-1)(n-2)….1 (realizzo un ciclo)
14
La ricorsione: definizione
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• Dal latino re-currere
 ricorrere, fare ripetutamente la stessa
azione
• In informatica: si tratta di
procedure/funzioni che richiamano se
stesse
• Il concetto di ricorsione viene usato nel
contesto di:
 algoritmi
 strutture dati
15
Scopo della programmazione ricorsiva
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• Lo scopo è quelo di risolvere un problema facendo
riferimento allo stesso problma su scala ridotta
• La condizione di terminazione avviene quando si
identifica uno o più casi semplici con soluzione
immediata
• La struttura di un algoritmo ricorsivo è il seguente
if (è il caso semplice)
risolvilo
else
usa la ricorsione su dati ridotti
16
La ricorsione: che cos’è?
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• Ricorsione indiretta:
 Un sottoprogramma P chiama un
sottoprogramma Q
 Q a sua volta chiama un terzo R, …
 R chiama nuovamente P
• Ricorsione diretta
 Un sottoprogramma P chiama se
stesso durante la propria esecuzione
17
Il calcolo del fattoriale
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
In matematica, se n è un intero positivo, si
definisce n fattoriale e si indica con n! il
prodotto dei primi n numeri interi positivi
minori o uguali di quel numero
18
Il main del fattoriale
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
19
Il fattoriale iterativo
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
20
Definizione ricorsiva del fattoriale
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
1) n!=1
se n=0
2) n!= n*(n-1)! se n>0
21
Definizione ricorsiva del fattoriale
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
1) n!=1
se n=0
2) n!= n*(n-1)! se n>0
 Riduce il calcolo a un calcolo più semplice
 Ha senso perché si basa sempre sul fattoriale
del numero più piccolo, che io conosco
 Ha senso perché si arriva a un punto in cui
non è più necessario riusare la def. 2) e
invece si usa la 1)
 1) è il passo base, 2) è il passo di ricorsione
22
Il fattoriale ricorsivo
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
Calcolo del Fattoriale in modo ricorsivo:
Fact(n)=n*Fact(n-1)
Fact(0)=1
n=3
main
23
Il fattoriale ricorsivo
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
Calcolo del Fattoriale in modo ricorsivo:
Fact(n)=n*Fact(n-1)
Fact(0)=1
fat=
FattRic(3)
n=3
main
24
Il fattoriale ricorsivo
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
Calcolo del Fattoriale in modo ricorsivo:
Fact(n)=n*Fact(n-1)
Fact(0)=1
fat=
FattRic(2)
fat=
FattRic(3)
n=3
main
25
Il fattoriale ricorsivo
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
Calcolo del Fattoriale in modo ricorsivo:
Fact(n)=n*Fact(n-1)
Fact(0)=1
fat=
FattRic(1)
fat=
FattRic(2)
fat=
FattRic(3)
n=3
main
26
Il fattoriale ricorsivo
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
Calcolo del Fattoriale in modo ricorsivo:
Fact(n)=n*Fact(n-1)
Fact(0)=1
fat=
FattRic(0)
fat=
FattRic(1)
fat=
FattRic(2)
fat=
FattRic(3)
n=3
main
27
Il fattoriale ricorsivo
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
Calcolo del Fattoriale in modo ricorsivo:
Fact(n)=n*Fact(n-1)
Fact(0)=1
fat=
1
FattRic(0)
fat=
FattRic(1)
fat=
FattRic(2)
fat=
FattRic(3)
n=3
main
28
Il fattoriale ricorsivo
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
Calcolo del Fattoriale in modo ricorsivo:
Fact(n)=n*Fact(n-1)
Fact(0)=1
fat=
1
FattRic(0)
fat=
1
FattRic(1)
fat=
FattRic(2)
fat=
FattRic(3)
n=3
main
29
Il fattoriale ricorsivo
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
Calcolo del Fattoriale in modo ricorsivo:
Fact(n)=n*Fact(n-1)
Fact(0)=1
fat=
1
FattRic(0)
fat=
1
FattRic(1)
fat=
2
FattRic(2)
fat=
FattRic(3)
n=3
main
30
Il fattoriale ricorsivo
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
Calcolo del Fattoriale in modo ricorsivo:
Fact(n)=n*Fact(n-1)
Fact(0)=1
fat=
1
FattRic(0)
fat=
1
FattRic(1)
fat=
2
FattRic(2)
fat=
6
FattRic(3)
n=3
main
31
Il fattoriale ricorsivo
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
Calcolo del Fattoriale in modo ricorsivo:
Fact(n)=n*Fact(n-1)
Fact(0)=1
fat=
1
FattRic(0)
fat=
1
FattRic(1)
fat=
2
FattRic(2)
fat=
6
FattRic(3)
6
main
32
Altri esempi di funzioni ricorsive
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• La moltiplicazione
• I numeri di Fibonacci (dinamiche di
popolazione)
• Il massimo in un array
• Il problema delle torri di Hanoi
33
Moltiplicazione
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• Ideare un procedimento ricorsivo per
calcolare il prodotto di due interi
34
Moltiplicazione
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• Ideare un procedimento ricorsivo per
calcolare il prodotto di due interi
• Nota: A*1=A; A*B = A + A*(B-1)
35
Moltiplicazione
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• Ideare un procedimento ricorsivo per
calcolare il prodotto di due interi
• Nota: A*1=A; A*B = A + A*(B-1)
int MulRic(int a, int b)
{
int ris;
if (b == 1) ris = a;
else ris = a + MulRic(a ,b–1);
return ris;
}
36
Fibonacci
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• Leonardo Fibonacci
 Matematico italiano
 Compie numerosi viaggi e
assimila le conoscenze
matematiche del mondo arabo,
 Nel 1202 pubblica: il Liber
abaci
 Con Liber abaci si propose di
diffondere nel mondo scientifico
occidentale le regole di calcolo
note agli Arabi
• il sistema decimale
37
Il problema dei “conigli”
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
“Un tale mise una coppia di conigli
in un luogo completamente
circondato da un muro, per scoprire
quante coppie di conigli
discendessero da questa in un anno:
per natura le coppie di conigli
generano ogni mese un'altra coppia
e cominciano a procreare a partire
dal secondo mese dalla nascita.”
L. Fibonacci da Liber Abaci
38
I numeri di Fibonacci
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
Idea di base
1) fib(n)=1 se n=0 opp. n=1
2) fib(n)= fib(n-1) + fib(n-2) se n>1
39
Successione di Fibonacci
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• Fib(n)=Fib(n-1)+Fib(n-2)
• Fib(0)=0; Fib(1)=1;
int fibRic (int n) {
int ris;
if (n == 0) ris = 0;
else if (n == 1) ris = 1;
else ris = fibRic(n–1) + fibRic(n–2);
return ris;
}
40
Massimo di un array
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• Ideare un procedimento ricorsivo per
calcolare il massimo di un array di interi
41
Massimo di un array
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• Ideare un procedimento ricorsivo per
calcolare il massimo di un array di interi
• Idea: max(vect[0 : N])
=max(vect[0],max(vect[1 : N]))
42
Massimo di un array
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• Ideare un procedimento ricorsivo per
calcolare il massimo di un array di interi
• Idea: max(vect[0 : N])
=max(vect[0],max(vect[1 : N]))
int max(int *array, int n){
int maxs;
if (n==1) return array[0]; /*Caso Array 1 elemento*/
if (n==2){
/*Caso Base*/
if (array[0]>array[1]) return array[0];
else return array[1];
}
maxs = max(&array[1],n-1); /*Risolvi Problema Ridotto*/
if (array[0]>maxs)return array[0];
else return maxs;
}
43
Un problema interessante:
La torre di Brahma
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
44
La leggenda
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• Narra la leggenda che all'inizio dei tempi, Brahma portò nel
grande tempio di Benares, sotto la cupola d'oro che si trova al
centro del mondo, tre colonnine di diamante e sessantaquattro
dischi d'oro, collocati su una di queste colonnine in ordine
decrescente, dal più piccolo in alto, al più grande in basso.
• E' la sacra Torre di Brahma che vede impegnati, giorno e notte, i
sacerdoti del tempio nel trasferimento della torre di dischi dalla
prima alla terza colonnina.
• Essi non devono contravvenire alle regole precise, imposte da
Brahma stesso, che richiedono di spostare soltanto un disco alla
volta e che non ci sia mai un disco sopra uno più piccolo.
• Quando i sacerdoti avranno completato il loro lavoro e tutti
i dischi saranno riordinati sulla terza colonnina, la torre e il
tempio crolleranno e sarà la fine del mondo.
45
Le torri di Hanoi
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
http://www.cs.cmu.edu/~cburch/survey/recurse/hanoi.html
Problema: spostare tutti i dischi dalla torre A alla torre B
(usando la torre C come “supporto intermedio”) in modo
che si trovino nello stesso ordine
46
Le torri di Hanoi
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• Scriveremo una funzione ricorsiva che
prende come parametro il numero del disco
più grande che vogliamo spostare (da 0 a 5
come nel disegno)
• La funzione prenderà anche tre parametri
che indicano:
 da quale asta vogliamo partire (source),
 a quale asta vogliamo arrivare (dest),
 l’altra asta, che possiamo usare come supporto
temporaneo (spare).
47
L’idea di base
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• Voglio spostare n anelli dal piolo sorgente,
a quello destinazione, usando come
appoggio il piolo ausiliario
 Devo quindi prima spostare n - 1 anelli dal
sorgente all'ausiliario, usando come appoggio
il piolo destinazione
 Poi sposto l'unico anello rimasto dal sorgente
al piolo destinazione
 Infine sposto gli n - 1 anelli che si trovano
sull'ausilliario all'anello destinazione..
48
L’uso della ricorsione
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• Quando si spostano gli n - 1 anelli la funzione
hanoi richiama se stessa, cioè effettua una
chiamata ricorsiva, semplificando però il
problema perché bisogna spostare un numero
di anelli inferiore.
• In pratica, con la ricorsione il problema viene
continuamente ridotto di complessità fino alla
soluzione banale in cui rimane solo un anello,
che viene semplicemente spostato nel piolo
destinazione.
49
Le torri di Hanoi: strategia
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
Ridurremo il problema a quello di spostare 5 dischi dalla torre C
alla torre B, dopo che il disco 5 è stato già messo nella posizione
giusta
50
Le torri di Hanoi: pseudocodice
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
FUNCTION MoveTower(disk, source, dest, spare):
IF disk == 0, THEN:
move disk from source to dest
ELSE:
MoveTower(disk - 1, source, spare, dest)
/* (Passo 1) */
move disk from source to dest
//
/* (Passo 2) */
MoveTower(disk - 1, spare, dest, source)
//
/* (Passo 3) */
END IF
Nota: l’algoritmo aggiunge un caso base: quando il disco è il più
piccolo (il numero 0). In questo caso possiamo muoverlo
direttamente perché non ne ha altri sopra. Negli altri casi,
seguiamo la procedura descritta per il disco 5.
51
Codice
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
void hanoi(int n, int sorgente, int destinazione, int aux) {
if (n==1)
printf("Sposto da %d a %d.\n",sorgente, destinazione);
else{
hanoi(n - 1, sorgente, aux, destinazione);
hanoi(1, sorgente, destinazione, aux);
hanoi(n - 1, aux, destinazione, sorgente);
}
}
52
Fonti per lo studio + Credits
DIPARTIMENTO DI ELETTRONICA E INFORMAZIONE
• Fonti per lo studio
 Introduzione alla programmazione in MATLAB,
A.Campi, E.Di Nitto, D.Loiacono, A.Morzenti,
P.Spoletini, Ed.Esculapio
• Capitolo 4
– Particolare attenzione al 4.5
• Credits
 Prof. A. Morzenti
 Gianluca Palermo
53