[PDF] Algorithmique Récursivité Algorithmique. Récursivité. Florent Hivert





Previous PDF Next PDF



Programme de numérique et sciences informatiques de première

Le concept de méthode algorithmique est introduit ; de nouveaux exemples seront vus en terminale. Quelques algorithmes classiques sont étudiés. L'étude de leurs 



TIC EN MATHÉMATIQUES-ALGORITHMIQUE Première journée

1 Algorithme et programmation dans les nouveaux programmes Les algorithmes d'Al-Khawarizmi : résolution d'équations de premier et second degré ...



Programme de mathématiques de première générale

L'enseignement de spécialité de mathématiques de la classe de première générale calculer appliquer des techniques et mettre en œuvre des algorithmes ;.



COURS ALGORITHMIQUE ET PROGRAMMATION INFORMATIQUE

12 mars 2013 Notion de sous-programmes et lien avec la compilation. • Qualité ... Avoir une première notion des performances des algorithmes utilisés.



Algorithmique & programmation en langage C - vol.1 - Archive

1 févr. 2019 Les premières provoquent la terminaison non-naturelle du programme. Autrement dit votre programme se termine alors qu'il ne devrait pas.



Algorithmique & programmation en langage C - vol.2 - Archive

14 juil. 2015 Installez le JDK en exécutant le programme que vous venez de ... Remarque : pour Linux la première ligne doit contenir un slash (/) à la ...



Algorithmique Récursivité

Algorithmique. Récursivité. Florent Hivert La Pile d'exécution (call stack) du programme en cours est un ... entré premier sorti. Attention !



livre-algorithmes.pdf

Nous allons voir qu'il est possible de calculer les premières décimales Faire un programme qui pour n'importe quel x ? calcule sin x



Algorithmique Structures de données

La plupart des bons algorithmes fonctionnent grâce à une méthode Durant l'exécution du programme l'action d'allocation ... première VD allouée :.



algorithmique.pdf

Algorithmes au programme. Voici l'algorithme qui correspond au programme de calcul. ... B. Quelles sont les coordonnées du premier point tracé ?

1 de 11

Algorithmique

Récursivité

Florent Hivert

Mél :Florent.Hivert@lri.fr

Adresse universelle :http://www.lri.fr/˜hivert

2 de 11

Récursivité et Récurrence

Deux notions très proche :mathématiques : récurrence informatique : récursivité De nombreuses définitions mathématiques sont récursives :Définition (Peano)

0 est un entier naturel.

Tout entierna un successeur uniqueSn(=n+1);Tout entier sauf0est le successeur d"un unique entier;Pour tout énoncéP(n)siP(0)est vrai et si pour toutn,P(n)

impliqueP(Sn)alors l"énoncé8n:P(n)est vrai.

3 de 11

Définition

Moyen simple et élégant de résoudre certain problème.Définition On appelle récursive toute fonction ou procédure qui s"appelle elle même.Algorithme Fact

Entrée : un entier positif N

Sortie : factorielle de N

si N = 0 retourner 1 sinon retourner N x Fact(N-1)

4 de 11

Exemple dans un vrai langage de programmation

unsigned int fact(unsigned int N) if (N == 0) return 1; else return N*fact(N-1);

4 de 11

Exemple dans un vrai langage de programmation

unsigned int fact(unsigned int N) if (N == 0) return 1; else return N*fact(N-1);

Ça marche!!!

5 de 11

Comment ça marche?

Appel à fact(4)

. 4*fact(3) = ? . Appel à fact(3) . . 3*fact(2) = ? . . Appel à fact(2) . . . 2*fact(1) = ? . . . Appel à fact(1) . . . . 1*fact(0) = ? . . . . Appel à fact(0) . . . . Retour de la valeur 1 . . . . 1*1 . . . Retour de la valeur 1 . . . 2*1 . . Retour de la valeur 2 . . 3*2 . Retour de la valeur 6 . 4*6

Retour de la valeur 24

6 de 11

Notion de pile d"exécution

Définition (Pile d"exécution)

LaPile d"exécution(call stack) du programme en cours est un emplacement mémoire destiner à mémo riserles pa ramètres,les variables locales ainsi que l"adresse de retour de chaque fonction en cours d"exécution.Elle fonctionne selon le principe LIFO (Last-In-First-Out) : dernier entré premier sorti.

Attention!

La pile à une taille fixée, une mauvaise utilisation de la récursivité peut entraîner un débordement de pile (stack overflow).

6 de 11

Notion de pile d"exécution

Définition (Pile d"exécution)

LaPile d"exécution(call stack) du programme en cours est un emplacement mémoire destiner à mémo riserles pa ramètres,les variables locales ainsi que l"adresse de retour de chaque fonction en cours d"exécution.Elle fonctionne selon le principe LIFO (Last-In-First-Out) : dernier entré premier sorti.Attention!La pile à une taille fixée, une mauvaise utilisation de la récursivité peut entraîner un débordement de pile (stack overflow).

6 de 11

Notion de pile d"exécution

Définition (Pile d"exécution)

LaPile d"exécution(call stack) du programme en cours est un emplacement mémoire destiner à mémo riserles pa ramètres,les variables locales ainsi que l"adresse de retour de chaque fonction en cours d"exécution.Elle fonctionne selon le principe LIFO (Last-In-First-Out) : dernier entré premier sorti.Attention!La pile à une taille fixée, une mauvaise utilisation de la récursivité peut entraîner un débordement de pile (stack overflow).

7 de 11

Point terminal

Retenir

Comme dans le cas d"une boucle, il faut un cas d"arrêt où l"on ne fait pas d"appel récursif.procédure récursive(paramètres): si TEST_D"ARRET: instructions du point d"arrêt sinon instructions récursive(paramètres changés); // appel récursif instructions

8 de 11

Détail d"un appel de fonction

PA =Programme App elant F

=F onctionapp elée1LeP Aréserveet initialise les pa ramètressur la pile 2transfert du contrôle duP AàF avec

enregistrement de l"adresse de retoursur la pile3réservation sur la pile des variables locales deF Retenir

L"ensemble : paramètres + adresse de retour + variables locales

constitue leTableau d"activation (Stack Frame)deF 4exécution du code deF dansson T Ajusqu"à return5désallocation du TA deF dela pile 6retour auP Aàl"adresse enregistrée à l"étap e2, avec

transmission de lavaleur de retourdans le cas échéant

9 de 11

La récursivité terminale

Définition

On dit qu"un fonction est récursive terminale, si tout appel récursif est de la formereturn f(...)Autrement dit, la valeur retournée est directement la valeur obtenue par un appel récursif, sans qu"il n"y ait aucune opération sur cette valeur. Il n"y a ainsi rien à retenir sur la pile.

Entrée : Entiers positifs n, a

Sortie : a*n!

si n == 0 retourner a sinon retourner Algo(n-1,n*a)

9 de 11

La récursivité terminale

Définition

On dit qu"un fonction est récursive terminale, si tout appel récursif est de la formereturn f(...)Autrement dit, la valeur retournée est directement la valeur obtenue par un appel récursif, sans qu"il n"y ait aucune opération sur cette valeur. Il n"y a ainsi rien à retenir sur la pile.Entrée : Entiers positifs n, a

Sortie : a*n!

si n == 0 retourner a sinon retourner Algo(n-1,n*a)

10 de 11

La récursivité terminale (2)

Idée : Il n"y a rien à retenir sur la pile.Retenir Quand une fonction est récursive terminale, on peut transformer l"appel récursif en une boucle, sans utilisation de mémoire supplémentaire.Attention!cette optimisation n"est pas supp ortéepa rtous les compilateurs et est optionnelle (ex :-O3avecgcc). si n == 0 retourner a sinon retourner Algo(n-1,n*a)

Devient :

Tant que n <> 0:

a <- n*a; n <- n-1 retourner a

10 de 11

La récursivité terminale (2)

Idée : Il n"y a rien à retenir sur la pile.Retenir Quand une fonction est récursive terminale, on peut transformer l"appel récursif en une boucle, sans utilisation de mémoire supplémentaire.Attention!cette optimisation n"est pas supp ortéepa rtous les compilateurs et est optionnelle (ex :-O3avecgcc). si n == 0 retourner a sinon retourner Algo(n-1,n*a)

Devient :

Tant que n <> 0:

a <- n*a; n <- n-1 retourner a

11 de 11

La récursivité terminale (3)

L"optimisation peut se faire appel par appel.Retenir Quand une appel est récursive terminal, on peut le transformer en un saut, sans utilisation de mémoire supplémentaire.Exemple : le tri rapide tri_rapide(tableau T, entier premier, entier dernier) si premier < dernier alors pivot := choix_pivot(T, premier, dernier) pivot := partitionner(T, premier, dernier, pivot) tri_rapide(T, premier, pivot-1) // Non terminal tri_rapide(T, pivot+1, dernier) // terminalquotesdbs_dbs35.pdfusesText_40
[PDF] Radiothérapie externe Accélérateur de particules

[PDF] ACCESSIBILITE DES ERP

[PDF] Je ne cherche pas, je trouve.

[PDF] Conséquences de la loi handicap 2005 sur le règlement de sécurité ERP

[PDF] Ajouter des ports USB 3.0 à son ordinàteur portàble

[PDF] LE MUSEE D ART MODERNE DE BELFORT OBTIENT LE LABEL «TOURISME ET HANDICAP».

[PDF] DOSSIER DE PRESENTATION

[PDF] Les réponses à vos questions

[PDF] RAPPORT 2012 EPREUVE DE MATHEMATIQUES CONCOURS DE RECRUTEMENT DE PROFESSEURS DES ECOLES

[PDF] STAGES DE PERFECTIONNEMENT

[PDF] Projet de délibération. Exposé des motifs. Mesdames, Messieurs,

[PDF] Bienvenue dans le Pays d Oloron Haut Béarn

[PDF] DOCUMENT DE TRAVAIL : ENQUÊTE ANNUELLE SUR LES DANS LES PME DE SEINE-SAINT SAINT DENIS (Données 2012)

[PDF] 0 811 555 550 Prix d un appel local depuis un poste fixe

[PDF] Université Hassan II Mohammedia Casablanca CENTRE DE FORMATION CONTINUE SITUATION ACTUELLE