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 :

Rendre itérative la fonction récursive


Sujet :

C

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2013
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Avril 2013
    Messages : 21
    Points : 25
    Points
    25
    Par défaut Rendre itérative la fonction récursive
    Bonjour a tous,

    Moi aussi j'ai trouvé des difficultés pour transformer cette fonction « recur » en une fonction itérative. Donc veuillez m'aider à la faire :

    voici la fonction :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    void F3_Rec (int x, int y)
    {
        Inst1 ; Inst2 ;
     
        if (x>0 && y>0)
        {
            x= x/10 ; y= y/10 ;
            F3_Rec (x,y) ;  
            Inst3 ; Inst4 ;
        }
     
        Inst5 ; Inst6 ;
        F3_Rec (x,y);
    }
    et voici ma réponse (chui sur qu'elle n'est pas bonne ) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    Void  F3_iter (int x,int y)
    {
        pile *P,*S;
     
        initpile(&P);
        initpile(&S) ;
     
        Inst1; Inst2 ;
     
        While(x>0 && y>0)
        {
            x=x/10 ; y=y/10 ;
            empiler(&P,x);
            empiler(&P,y);
     
            inst1; inst2;
        }
     
        {
            inst5; inst6;
        }
     
        while (!pilevide(P))
        {
            depiler(&P,&y);
            depiler(&P,&x);
            inst3; inst4; inst5; inst6;
            empiler(&S,&x);
            empiler(&S,&y);
        }
     
        while( !pilevide(S))
        {
            depiler(&S,&y);
            depiler(&S,&x);
            inst1 ;inst2 ;
            {inst5 ;inst6 ;}
     
            while (!pilevide(S))
            {
                depiler(&S,&y);
                depiler(&S,&x);
                inst3 ;inst4 ;inst5 ;inst6 ;
            }

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut

    Est-ce normal que ce soit du "itératif avec pile" plutôt que tu vrai itératif? Cela respecte-t-il la consigne?

    Edit: Aussi, est-ce normal que cette fonction n'ait aucune condition de retour? Et a-t-on droit au goto?
    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.

  3. #3
    Membre expert
    Avatar de kwariz
    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Octobre 2011
    Messages
    898
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2011
    Messages : 898
    Points : 3 352
    Points
    3 352
    Par défaut
    Citation Envoyé par Médinoc Voir le message

    Est-ce normal que ce soit du "itératif avec pile" plutôt que tu vrai itératif? Cela respecte-t-il la consigne?

    Edit: Aussi, est-ce normal que cette fonction n'ait aucune condition de retour? Et a-t-on droit au goto?
    Hello,

    quand je vois (vraiment en premier jet) des instructions comme x=x/10 (avec x un int) avant un appel récursif et dont les valeurs peuvent être utilisées par la suite je me dis que l'on ne pourra pas se passer de pile car la division entière n'est pas inversible.
    Personnellement je ne trouve pas qu'il y ait du vrai itératif ou du faux itératif mais je comprends ce que tu veux dire, sans utiliser une pile qui mimerait la pile récursive :-D
    En revanche je m'inquiète aussi de la condition d'arrêt car dans l'état F3_Rec est une boucle sans fin (en supposant même que les paramètres sont positifs ...), peut-être un return dans le if ????

  4. #4
    Membre expert
    Avatar de Metalman
    Homme Profil pro
    Enseignant-Chercheur
    Inscrit en
    Juin 2005
    Messages
    1 049
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Enseignant-Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 1 049
    Points : 3 532
    Points
    3 532
    Par défaut
    Hmmm... je plussoie kwariz : la boucle imbriquée à la fin me parait bizarre : c'est la même condition qui les fini...
    Ca veut dire que tu fais un tour de la boucle principale, puis tu vides ta pile sur la boucle imbriquée....
    --
    Metalman !

    Attendez 5 mins après mes posts... les EDIT vont vite avec moi...
    Les flags de la vie : gcc -W -Wall -Werror -ansi -pedantic mes_sources.c
    gcc -Wall -Wextra -Werror -std=c99 -pedantic mes_sources.c
    (ANSI retire quelques fonctions comme strdup...)
    L'outil de la vie : valgrind --show-reachable=yes --leak-check=full ./mon_programme
    Et s'assurer que la logique est bonne "aussi" !

    Ma page Developpez.net

  5. #5
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 690
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 690
    Points : 30 984
    Points
    30 984
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par 1abdou1 Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    void F3_Rec (int x, int y)
    {
        Inst1 ; Inst2 ;
     
        if (x>0 && y>0)
        {
            x= x/10 ; y= y/10 ;
            F3_Rec (x,y) ;  
            Inst3 ; Inst4 ;
        }
     
        Inst5 ; Inst6 ;
        F3_Rec (x,y);
    }
    Bonjour

    Moi je me demande déjà quand s'arrête cette fonction (et accessoirement si Inst3 et Inst4 seront même exécutés un jour)...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  6. #6
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2013
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Avril 2013
    Messages : 21
    Points : 25
    Points
    25
    Par défaut
    Citation Envoyé par Médinoc Voir le message

    Est-ce normal que ce soit du "itératif avec pile" plutôt que tu vrai itératif? Cela respecte-t-il la consigne?

    Edit: Aussi, est-ce normal que cette fonction n'ait aucune condition de retour? Et a-t-on droit au goto?
    oui ;c'est avec une pile qu'on elimine la recursivité mais je sais pas comment
    help please;

  7. #7
    Nouveau membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2013
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Avril 2013
    Messages : 21
    Points : 25
    Points
    25
    Par défaut
    Citation Envoyé par Sve@r Voir le message
    Bonjour

    Moi je me demande déjà quand s'arrête cette fonction (et accessoirement si Inst3 et Inst4 seront même exécutés un jour)...
    ben moi je ne sais pas quand elle va s'arrter mais si tu veut voir l'enoncé c'est le 1er exercice de ce devoir tien :
    http://www.4shared.com/file/SfzdJTWK/Devoir1_2013.html?

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    McAfee me gueule dessus quand je tente de DL ton document sur 4shared.
    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.

  9. #9
    Membre expert
    Avatar de kwariz
    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Octobre 2011
    Messages
    898
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2011
    Messages : 898
    Points : 3 352
    Points
    3 352
    Par défaut
    Bon, avec le code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    void F3_Rec (int x, int y)
    {
        Inst1 ; Inst2 ;
     
        if (x>0 && y>0)
        {
            x= x/10 ; y= y/10 ;
            F3_Rec (x,y) ;  
            Inst3 ; Inst4 ;
        }
     
        Inst5 ; Inst6 ;
        F3_Rec (x,y);
    }
    on voit qu'on commence par un inst1;inst2; puis tant que les deux paramètres sont strictement positifs on les divise par 10, l'appel récursif nous fait exécuter inst1;inst2;. Une fois qu'un des deux n'est plus strictement positif on fait une boucle infinie sur inst5;inst6;inst1;inst2;
    D'où :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    F3_iter(int x, int y)
    {
      inst1;inst2;
      while ( x>0 && y>0 ) {
        x=x/10;
        y=y/10;
        inst1; inst2;
      }
      while (1) {
        inst5;inst6;
        inst1;inst2;
      }
    }
    Cela en supposant que inst1 à inst6 ne font rien de particulier ...

  10. #10
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 690
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 690
    Points : 30 984
    Points
    30 984
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    McAfee me gueule dessus quand je tente de DL ton document sur 4shared.
    C'est normal, t'as dû cliquer sur "pririty download" le gros bouton bleu. Là, au lieu de te filer le document, ça te file un exécutable sensé ensuite télécharger lui-même le document et te le déposer sur ton bureau (pourquoi en effet faire simple...). Et face aux exécutables inconnus, n'importe qui d'un peu sensé a un mouvement de recul et, s'il doit l'exécuter, le fait dans une machine virtuelle elle-même située de préférence sous un bon vieux Linux des familles...

    Mais si tu veux télécharger son docx de façon classique, faut cliquer sur "téléchargez" juste au dessus et ensuite te créer un compte avec email et mot de passe pour ensuite pouvoir télécharger (ai-je vraiment dit "classique" ???)

    Sinon donc j'ai téléchargé son docx et je le joins ici. Et mis à part cette fonction qui (pour moi) ne peut pas fonctionner (il y en a 3 autres du même acabit), son devoir est très très banal (comment insérer, supprimer, parcourir un arbre en récursif)...

    Ah oui, j'oubliais, comme c'est un devoir à rendre pour aujourd'hui je pense que le topic sera périmé dès demain...

    Citation Envoyé par kwariz Voir le message
    Bon, avec le code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    void F3_Rec (int x, int y)
    {
        Inst1 ; Inst2 ;
     
        if (x>0 && y>0)
        {
            x= x/10 ; y= y/10 ;
            F3_Rec (x,y) ;  
            Inst3 ; Inst4 ;
        }
     
        Inst5 ; Inst6 ;
        F3_Rec (x,y);
    }
    on voit qu'on commence par un inst1;inst2; puis tant que les deux paramètres sont strictement positifs on les divise par 10, l'appel récursif nous fait exécuter inst1;inst2;. Une fois qu'un des deux n'est plus strictement positif on fait une boucle infinie sur inst5;inst6;inst1;inst2;
    Mais après Inst6, ça rappelle F3_Rec() sans condition ce qui introduit un nouveau contexte et non pas une boucle. Alors en effet ça exécutera de nouveau Inst1 mais ça sera dans une autre pile et etc jusqu'au plantage...
    Fichiers attachés Fichiers attachés
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  11. #11
    Membre expert
    Avatar de kwariz
    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Octobre 2011
    Messages
    898
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2011
    Messages : 898
    Points : 3 352
    Points
    3 352
    Par défaut
    Citation Envoyé par Sve@r Voir le message
    [...]
    Mais après Inst6, ça rappelle F3_Rec() sans condition ce qui introduit un nouveau contexte et non pas une boucle. Alors en effet ça exécutera de nouveau Inst1 mais ça sera dans une autre pile et etc jusqu'au plantage...
    Une autre pile ??? Il n'y a qu'une pile à ma connaissance. Effectivement la version récursive ne peut que planter avec un stackoverflow, mais a priori la version itérative ne plantera jamais en ayant le même résultat attendu. Mais bon, il s'agit d'un pseudo code c-like, pas une vraie implémentation.

    Enfin, comme tu dis ce sujet est périmé et nous répondons apparemment à une question qui n'est même pas posée.

  12. #12
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 690
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 690
    Points : 30 984
    Points
    30 984
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par kwariz Voir le message
    Une autre pile ??? Il n'y a qu'une pile à ma connaissance.
    Je voulais dire "un autre contexte d'exécution de la fonction" mais j'avais déjà employé le mot "contexte"...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  13. #13
    Membre expert
    Avatar de kwariz
    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Octobre 2011
    Messages
    898
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2011
    Messages : 898
    Points : 3 352
    Points
    3 352
    Par défaut
    Citation Envoyé par Sve@r Voir le message
    Je voulais dire "un autre contexte d'exécution de la fonction" mais j'avais déjà employé le mot "contexte"...
    Citation Envoyé par Sve@r Voir le message
    Mais après Inst6, ça rappelle F3_Rec() sans condition ce qui introduit un nouveau contexte et non pas une boucle.
    Mais du coup au premier appel récursif après le if, on tombe sur un cas de récursivité terminale et ça se transforme bien en une boucle qui dans cet exemple n'a pas de condition d'arrêt donc un boucle infinie, non ?

  14. #14
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 690
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 690
    Points : 30 984
    Points
    30 984
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par kwariz Voir le message
    Mais du coup au premier appel récursif après le if, on tombe sur un cas de récursivité terminale et ça se transforme bien en une boucle qui dans cet exemple n'a pas de condition d'arrêt donc un boucle infinie, non ?
    Pour qu'il y ait récursivité "terminale", il faut qu'à un moment où un autre la fonction se "termine" (par un return d'une valeur simple ou un return tout court dans le cas d'une fonction void).

    Ici, il n'y a jamais aucun retour. La fonction se rappelle elle-même à l'infini...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Citation Envoyé par Sve@r Voir le message
    Pour qu'il y ait récursivité "terminale", il faut qu'à un moment où un autre la fonction se "termine" (par un return d'une valeur simple ou un return tout court dans le cas d'une fonction void).
    Je crois qu'on a deux notions différentes de "récursivité terminale" (et possiblement deux contextes différents).

    Pour moi et kwariz, on peut parler de récursivité terminale ("tail recursion") dès que l'appel récursif est la dernière chose effectuée par la fonction ("tail call"), indépendamment de toute notion de condition d'arrêt.
    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.

  16. #16
    Membre expert
    Avatar de Metalman
    Homme Profil pro
    Enseignant-Chercheur
    Inscrit en
    Juin 2005
    Messages
    1 049
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Enseignant-Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 1 049
    Points : 3 532
    Points
    3 532
    Par défaut
    Il n'y a pas que ça d'étrange dans le sujet.... cf la date de rendu...

    [Oui ce post n'est pas très constructif]
    --
    Metalman !

    Attendez 5 mins après mes posts... les EDIT vont vite avec moi...
    Les flags de la vie : gcc -W -Wall -Werror -ansi -pedantic mes_sources.c
    gcc -Wall -Wextra -Werror -std=c99 -pedantic mes_sources.c
    (ANSI retire quelques fonctions comme strdup...)
    L'outil de la vie : valgrind --show-reachable=yes --leak-check=full ./mon_programme
    Et s'assurer que la logique est bonne "aussi" !

    Ma page Developpez.net

  17. #17
    Membre expert
    Avatar de kwariz
    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Octobre 2011
    Messages
    898
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2011
    Messages : 898
    Points : 3 352
    Points
    3 352
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    Je crois qu'on a deux notions différentes de "récursivité terminale" (et possiblement deux contextes différents).

    Pour moi et kwariz, on peut parler de récursivité terminale ("tail recursion") dès que l'appel récursif est la dernière chose effectuée par la fonction ("tail call"), indépendamment de toute notion de condition d'arrêt.
    Oui c'est ça. Une fonction récursive terminale se transforme souvent aisément en version itérative avec une simple boucle.

  18. #18
    Modérateur
    Avatar de Obsidian
    Homme Profil pro
    Développeur en systèmes embarqués
    Inscrit en
    Septembre 2007
    Messages
    7 371
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur en systèmes embarqués
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2007
    Messages : 7 371
    Points : 23 626
    Points
    23 626
    Par défaut
    Citation Envoyé par Sve@r Voir le message
    Ah oui, j'oubliais, comme c'est un devoir à rendre pour aujourd'hui je pense que le topic sera périmé dès demain...
    Surtout quand on prend connaissance des avertissements en fin de document :

    Citation Envoyé par Le prof
    • Le travail doit être remis individuellement le samedi 07/04/2013 ;
    • Les programmes écrits doivent être lisibles, bien commentés et remis sous forme de listing (imprimés) ;
    • Aucun retard ne sera toléré ;
    • Les cas de copiage seront sévèrement sanctionnés.

Discussions similaires

  1. Fonction récursive vers itérative.
    Par MilkyMars dans le forum Lisp
    Réponses: 2
    Dernier message: 30/11/2012, 17h14
  2. [VB6] XML, fonction récursive de recherche
    Par kboo dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 24/04/2006, 21h27
  3. [XSLT] fonction récursive à N niveaux
    Par Mike35 dans le forum XSL/XSLT/XPATH
    Réponses: 2
    Dernier message: 10/03/2006, 12h30
  4. Fonction récursive renvoi sur page d'erreur
    Par peck dans le forum Langage
    Réponses: 1
    Dernier message: 23/12/2005, 10h08
  5. Problème de fonction récursive avec un TcxDBTreeList
    Par isachat666 dans le forum Composants VCL
    Réponses: 1
    Dernier message: 05/12/2005, 13h12

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