Maison > développement back-end > Tutoriel Python > Comprendre la récursivité en Python : alors, allez-vous y faire face ?

Comprendre la récursivité en Python : alors, allez-vous y faire face ?

Linda Hamilton
Libérer: 2024-10-31 18:10:14
original
538 Les gens l'ont consulté

Entendendo Recursão em Python: E aí, vai encarar?

La récursion est un concept fondamental en programmation, mais elle peut parfois sembler un peu mystérieuse. Alors, simplifions cela et voyons que c'est plus facile qu'il n'y paraît !

Qu’est-ce que la récursivité ?

La récursivité, c'est lorsqu'une fonction résout un problème en s'appelant... elle-même ! Oui, c'est vrai. Cela fonctionne comme une histoire que vous racontez encore et encore, mais un peu plus courte à chaque fois jusqu'à la fin. Mais pour que cela fonctionne correctement, il doit respecter deux règles d'or :

  1. Condition de terminaison : c'est le point où la fonction doit s'arrêter, sinon elle restera dans une boucle éternelle (on ne veut pas ça, non ?).
  2. Auto-appel : c'est à ce moment-là que la fonction s'appelle elle-même, en allant de plus en plus profondément jusqu'à atteindre la condition de terminaison.

Voyons maintenant comment cela fonctionne en pratique !

Comment ça marche ?

Pour mieux l'expliquer, rien de mieux que l'exemple classique du factorial ! Imaginez que nous voulions calculer (5 !) (lire « factorielle cinq »). Comment ça marche ?

5 ! = 5*4*3*2*1 !

Cependant, avec la récursivité, on peut y penser comme ceci :

5 ! = 5*4 !

Et, dans l'ordre, 4 ! vaut (4 * 3 !), et ainsi de suite, jusqu'à atteindre (1 !), qui est notre cas de base (la terminaison état).

Exemple pratique : factoriel

Passons au code, car c'est là que le concept prend vie ! Voici le fameux calcul factoriel utilisant la récursion :

def fatorial(numero):
    if numero == 0 or numero == 1:
        return 1  # caso base
    else:
        return numero * fatorial(numero - 1)
Copier après la connexion

Explication :

  1. Le cas de base ici est lorsque le nombre est 0 ou 1, où la fonction renvoie simplement 1.
  2. Si le nombre est supérieur à 1, la fonction est appelée avec le numéro - 1, accumulant les valeurs jusqu'au cas de base.

Complexité

  • Heure : (O(n)) — puisqu'il y a n appels récursifs.
  • Espace : (O(n)) — la profondeur de la pile d'exécution est n.

Exemple pratique : Fibonacci

Un autre exemple largement utilisé est la Séquence de Fibonacci. Elle est comme ça :

f(0) = 0, f(1) = 1, f(n) = f(n - 1) f(n - 2)

Passons au code !

def seq_fib(n):
    if n == 0:
        return 0
    if n == 1:
        return 1
    if n > 1:
        return seq_fib(n - 1) + seq_fib(n - 2)
Copier après la connexion

Complexité de Fibonacci :

  • Temps : (O(2^n)) — exponentiel ! ⚠️
  • Espace : (O(n)) — utilisation de la pile pour les appels récursifs.

C'est pourquoi, pour les grandes valeurs, le calcul de Fibonacci avec récursion pure peut s'avérer un peu fastidieux. Mais à des fins d'apprentissage, c'est un excellent exemple !

Enfin

La récursion est un concept clé en programmation et, même si cela peut paraître un peu intimidant au début, cela devient beaucoup plus facile avec la pratique. Ces exemples factoriels et de Fibonacci ne sont qu’un début !

Si vous souhaitez vous entraîner, consultez-le et faites-en une copie, dans ce Colab ici !

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:dev.to
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal