IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C Discussion :

pile & récursivité ?


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre très actif
    Inscrit en
    Août 2007
    Messages
    260
    Détails du profil
    Informations forums :
    Inscription : Août 2007
    Messages : 260
    Par défaut pile & récursivité ?
    Salut
    Je vx savoir quelle est la relation entre les piles et la récursivité ?
    Et si vous pouvez me donner un exemple sur la fonction factoriel et les piles

  2. #2
    Expert confirmé

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 610
    Détails du profil
    Informations personnelles :
    Âge : 67
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 610
    Billets dans le blog
    2
    Par défaut
    la récursivité se faisant sur la pile, sa limite est celle de la pile. D'autant plus si on a beaucoup de variables prises sur la pile..

    Donc une fonction récursive à 30 paramètres appelées quelques milliers (10 aines de ??) de fois provoquera un crash...

    La relation est donc d'être bien conscient de cette limite...

  3. #3
    Membre très actif
    Inscrit en
    Août 2007
    Messages
    260
    Détails du profil
    Informations forums :
    Inscription : Août 2007
    Messages : 260
    Par défaut
    Citation Envoyé par juve1897 Voir le message
    A priori, je serait tenté de dire aucune, mais bon as tu un enoncé plus precis?
    Dans mon cours de cette année au chapitre de la récursivité on l'a fais relire avec la notion des piles mais avec une explication très brève ...

    souviron34
    Si tu peux expliquer en illustrant avec un exemple sur la factoriel

  4. #4
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par yous18 Voir le message
    Salut
    Je vx savoir quelle est la relation entre les piles et la récursivité ?
    Et si vous pouvez me donner un exemple sur la fonction factoriel et les piles
    La récursivité utilise la mémoire automatique pour empiler les retours de fonctions, les paramètres et les résultats intermédiaires. C'est une manière, certes, 'élégante' de programmer, mais qui a des défauts :
    • La taille de la mémoire automatique est limitée.
    • Il n'y a pas de moyen standard de modifier ni même de connaitre la limite.
    • En cas de débordement le comportement est indéfini.
    • Il n'y a pas de moyen standard de savoir si on a atteint la limite.

  5. #5
    Membre très actif
    Inscrit en
    Août 2007
    Messages
    260
    Détails du profil
    Informations forums :
    Inscription : Août 2007
    Messages : 260
    Par défaut
    merci mais je vx un exemple
    on fais cette instruction en fonction
    int fact(int n)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    {
    if (n==0) return 1;
    else
    return n*fact(n-1);
    }
    si on appel la fonction dans le main :quel sont les étape executer dans la pile ?

  6. #6
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 395
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    C'est une récursivité non-terminale.
    Les étapes ici sont (sur une machine avec une pile, comme un Intel x86 ou un M68k) :

    --dans le main:
    empiler 4
    empiler l'adresse de retour
    --dans fact:
    comparer 4 à 0
    calculer 4-1 = 3
    empiler 3
    empiler l'adresse de retour
    ---
    comparer 3 à 0
    calculer 2-1 = 2
    empiler 2
    empiler l'adresse de retour
    ---
    comparer 2 à 0
    calculer 2-1 = 1
    empiler 1
    empiler l'adresse de retour
    ---
    comparer 1 à 0
    calculer 1-1 = 0
    empiler 0
    empiler l'adresse de retour
    ---
    comparer 0 à 0
    retourner 1
    dépiler l'adresse de retour
    ---
    calculer 2*1
    retourner 2
    dépiler l'adresse de retour
    ---
    calculer 3*2
    retourner 6
    dépiler l'adresse de retour
    ---
    calculer 4*6
    retourner 24
    dépiler l'adresse de retour
    --dans le main:
    suite...
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  7. #7
    Rédacteur

    Avatar de millie
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    7 015
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 7 015
    Par défaut
    Avant d'avoir un soucis avec la pile, tu auras un soucis avec le calcul de la factoriel en elle même.

    On a : n!>=2^n.
    Sur beaucoup de systèmes (ce n'est pas toujours le cas, attention), la taille d'un int est de 4 octets = 32 bits. Ce qui ne permet pas de représenter un entier plus grand que 2^33, donc tu ne peux pas calculer 33! (et encore, j'ai pris une énorme marge avec n!>2^n).

    Donc si tu te limites aux valeurs où la factoriel est effectivement calculable, il n'y aura, normalement, pas de problème avec la pile... Mais l'algorithme étant tellement simple sans appel récursif, pourquoi s'en priver.


    yous18 : Ta fonction plante si on fait fact(-1)

  8. #8
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 395
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    Tu sais, quatre octets ça fait 32 bits, pas 64...
    PS: La factorielle dépasse la puissance de 2 à partir de n=4.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Cours : algorithmes et récursivité
    Par Community Management dans le forum Algorithmes et structures de données
    Réponses: 3
    Dernier message: 17/10/2018, 00h38
  2. Récursivité et dépassement de pile...
    Par MasterOfChakhaL dans le forum Général JavaScript
    Réponses: 20
    Dernier message: 17/05/2006, 01h11
  3. Etat de la pile sous Linux et Windows
    Par Bibouda dans le forum x86 32-bits / 64-bits
    Réponses: 7
    Dernier message: 16/02/2003, 01h28
  4. La mémoire en Pmode et en Rmode - la pile
    Par le mage tophinus dans le forum Assembleur
    Réponses: 15
    Dernier message: 16/02/2003, 01h00
  5. [TASM] Déclarer le segment de pile
    Par cipher dans le forum x86 16-bits
    Réponses: 2
    Dernier message: 01/10/2002, 03h58

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo