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 :

Nombre d'appel de fonction


Sujet :

C

  1. #1
    Débutant  
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    1 122
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2003
    Messages : 1 122
    Points : 189
    Points
    189
    Par défaut Nombre d'appel de fonction
    Bonjour tout le monde

    Voici une fonction de fibbonnaci en recurcive.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    int recurc(int fn)
    {
    int tim=0;
    tim=tim+1;
     
    if(fn<=1)
    {
    return fn;
    }
    else
    {
      return recurc(fn-1) + recurc(fn-2);
    }
    J'aurais besoin d'aide pour afficher le nombre d'appel de cet fonction

    J'ai regarder dans mon livre et j'ai chercher sur le net, je n'ai pas trouvé.

    Pouvez vous m'aider?

    Merci

    Cordialement
    je suis un développeur debutant qui cherche à comprendre.

    Certain livre sont pas facile à comprendre.

  2. #2
    Membre éclairé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    1 298
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 1 298
    Points : 886
    Points
    886
    Par défaut
    salut, il y a deux solutions

    1) tu utilises une variable static que tu incrémentes à chaque appel
    2) tu peux utilser le profiler

  3. #3
    Débutant  
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    1 122
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2003
    Messages : 1 122
    Points : 189
    Points
    189
    Par défaut
    Re

    je vais utiliser cet solution.

    tu utilises une variable static que tu incrémentes à chaque appel
    Dois créer une fonction.

    Car la je ne voix pas comment commencer.

    A +
    je suis un développeur debutant qui cherche à comprendre.

    Certain livre sont pas facile à comprendre.

  4. #4
    Membre confirmé
    Inscrit en
    Juillet 2005
    Messages
    512
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 512
    Points : 641
    Points
    641
    Par défaut
    moi je ferais une fonction compteur à part :

    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
    #define READ 0
    #define COUNT 1
    #define RAZ 2
     
    int counter(int action)
    {
       static ct=0;
       switch(action){
         case READ return ct;
         case COUNT ct++;
              break;
         case RAZ ct=0;
       }
       return ct;
    }
     
    int recurc(int fn)
    {
      counter(COUNT);
     
      if(fn<=1)   return fn;
     
      else  return recurc(fn-1) + recurc(fn-2);
    }

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

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Points : 20 985
    Points
    20 985
    Par défaut
    Citation Envoyé par Lucien63
    moi je ferais une fonction compteur à part :
    Bien qu'astucieux, ce code est faux (ne compile pas). Merci de tester le code avant de le proposer.

    Ceci dit, il y a plus simple :
    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
     
    #include <stdio.h>
     
    int recurc (int fn, int *p_cnt)
    {
       (*p_cnt)++;
     
       if (fn <= 1)
          return fn;
     
       else
          return recurc (fn - 1, p_cnt) + recurc (fn - 2, p_cnt);
    }
    int main (void)
    {
       int ct = 0;
       int n = recurc (20, &ct);
     
       printf ("n = %d count = %d\n", n, ct);
     
       return 0;
    }
    Pas de Wi-Fi à la maison : CPL

  6. #6
    Membre confirmé
    Inscrit en
    Juillet 2005
    Messages
    512
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 512
    Points : 641
    Points
    641
    Par défaut
    Bien qu'astucieux, ce code est faux (ne compile pas). Merci de tester le code avant de le proposer.
    C'est vrai, j'ai oublié les : des cases

    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
    #define READ 0
    #define COUNT 1
    #define RAZ 2
     
    int counter(int action)
    {
       static ct=0;
       switch(action){
         case READ : return ct;
         case COUNT : ct++;
              break;
         case RAZ : ct=0;
       }
       return ct;
    }
     
    int recurc(int fn)
    {
      counter(COUNT);
     
      if(fn<=1)   return fn;
     
      else  return recurc(fn-1) + recurc(fn-2);
    }

  7. #7
    Expert éminent sénior
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 614
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 614
    Points : 30 626
    Points
    30 626
    Par défaut
    Salut,

    La méthode la plus simple est, souvent, la meilleure...

    Et, dans le cas, la méthode la plus simple consiste, tout simplement, à modifier un tout petit peu le prototype de la fonction, et du coup, son fonctionnement:
    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
     
    /* @in: fn=valeur à calculer
     *      *cpt= pointeur sur le compteur
     */
    int recurc(int fn, int *cpt)
    {
        /* juste incrémenter avant toute chose la valeur pointée par cpt */
        (*cpt)++;
     
        if(fn<=1)
        {
            return fn;
        }
        else
        {
          return recurc(fn-1, cpt) + recurc(fn-2,cpt);
        }
    }
    et l'appel se faisant sous la forme de
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    int main()
    {
        int ct = 0;
        int n = recurc (20, &ct);
        printf ("n = %d count = %d\n", n, ct);
        return 0;
    }
    Et le tour est joué

    Une autre solution, que je n'apprécie que médiocrement, consiste à placer le compteur directement dans une variable globale, histoire de ne pas avoir à modifier le prototype de 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
    15
    16
    17
    18
    19
    20
    21
    22
    int cpt;
    int recurc(int fn)
    {
        /* juste incrémenter avant toute chose la valeur de cpt */
        cpt++;
     
        if(fn<=1)
        {
            return fn;
        }
        else
        {
          return recurc(fn-1) + recurc(fn-2);
        }
    }
    int main()
    {
        cpt = 0;/* initialisation à 0 avant de commencer */
        int n = recurc (20);
        printf ("n = %d count = %d\n", cpt);
        return 0;
    }
    Pourquoi donc s'emm à faire du compliqué là ou du simple suffit amplement
    A méditer: La solution la plus simple est toujours la moins compliquée
    Ce qui se conçoit bien s'énonce clairement, et les mots pour le dire vous viennent aisément. Nicolas Boileau
    Compiler Gcc sous windows avec MinGW
    Coder efficacement en C++ : dans les bacs le 17 février 2014
    mon tout nouveau blog

  8. #8
    Débutant  
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    1 122
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2003
    Messages : 1 122
    Points : 189
    Points
    189
    Par défaut
    Bonjour tout le monde

    Ca fonctionne

    Merci beaucoup pour votre aide.

    Cordialement

    A bientôt
    je suis un développeur debutant qui cherche à comprendre.

    Certain livre sont pas facile à comprendre.

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

Discussions similaires

  1. Fonction récursive : compter le nombre d'appels
    Par Dombrai dans le forum MATLAB
    Réponses: 2
    Dernier message: 01/10/2014, 11h37
  2. Réponses: 8
    Dernier message: 08/06/2006, 17h05
  3. [JSP] Appeler une fonction
    Par Patrick95 dans le forum Servlets/JSP
    Réponses: 10
    Dernier message: 23/12/2003, 13h44
  4. Appel à des fonctions incluses dans des DLL
    Par Greybird dans le forum Langage
    Réponses: 3
    Dernier message: 26/05/2003, 13h33
  5. Appeler une fonction avec/sans parenthèses
    Par haypo dans le forum Algorithmes et structures de données
    Réponses: 8
    Dernier message: 29/12/2002, 18h48

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