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 :

factoriel d'un nombre N


Sujet :

C

  1. #1
    Membre régulier
    Profil pro
    Étudiant
    Inscrit en
    Novembre 2006
    Messages
    114
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2006
    Messages : 114
    Points : 75
    Points
    75
    Par défaut factoriel d'un nombre N
    bsoir;
    voila, j'ai une petite question a vous posez,
    comment je peux utiliser le language C pour calculer le factoriel d'un nombre quelconque....? j'ai du mal traduir la formule..
    merci pour votre temps

  2. #2
    Rédacteur

    Profil pro
    Étudiant
    Inscrit en
    Juin 2004
    Messages
    113
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : Maroc

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2004
    Messages : 113
    Points : 276
    Points
    276
    Par défaut
    Soit une boucle, soit une fonction récursive

  3. #3
    Membre régulier
    Profil pro
    Étudiant
    Inscrit en
    Novembre 2006
    Messages
    114
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2006
    Messages : 114
    Points : 75
    Points
    75
    Par défaut
    voila ce que j'ai arrivé à faire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    int fact(int n){
     int i,j;
      j = 1;
    for (i==1;i<=n;i++) {
        j = j * i;
      fact = j;
    }
    return n;
    mais j'ai une erreur au niveau de "fact = j ;" (Lvalue required)
    je sais pas ce que ca veut dire..

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    633
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 633
    Points : 711
    Points
    711
    Par défaut
    Bonjour,

    Relis tes cours ou ta documentation ou livre...

    Ou as-tu pris ceci par exemple
    Tu peux me citer un cours, une doc ou n'importe quoi de sérieux qui montre l'utilisation du nom d'une fonction comme tu le fais ?

    En plus, ton compilateur s'en plaint (heureusement !), ce qui aurait dû t'amener à vérifier.

    et puis plus loin
    Tu renvoies le paramètre alors que tu ne l'as pas modifié ?

    De plus
    Révise la signification de ==

    Pour devenir programmeur, même en amateur, il ne faut pas écrire des trucs au hasard, il faut apprendre, et faire l'effort d'être logique dans ce qu'on écrit.
    Et quand le compilateur te donne des messages d'erreur, il faut essayer de comprendre ce qui se passe.

    Et petite remarque habituelle : l'indentation de ton code n'est pas correcte, car non régulière.
    C'est également un point important à respecter, sinon les codes deviennent rapidement quasiment illisibles.
    Compilation sans erreur ne signifie pas programme sans erreur.
    L'indentation n'a pas été imaginée pour faire beau, mais pour faciliter la lecture des programmes.

  5. #5
    Rédacteur
    Avatar de Franck.H
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Janvier 2004
    Messages
    6 951
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Haut Rhin (Alsace)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Service public

    Informations forums :
    Inscription : Janvier 2004
    Messages : 6 951
    Points : 12 462
    Points
    12 462
    Par défaut
    Dans mon tutoriels sur la récursivité, j'ai justement pris comme exemple le calcul du factoriel d'un nombre, tu as toutes les réponses: Récursivité en Langage C
    Mon Site
    Ma bibliothèque de gestion des chaînes de caractères en C

    L'imagination est plus importante que le savoir. A. Einstein

    Je ne répond à aucune question technique par MP, merci d'avance !

  6. #6
    Expert confirmé
    Avatar de Thierry Chappuis
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Mai 2005
    Messages
    3 499
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Suisse

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 499
    Points : 5 360
    Points
    5 360
    Par défaut
    Salut,

    Voici ton code corrigé, indenté, et commenté. Note que j n'est pas optimal comme nom pour calculer le résultat de ta factorielle (pourquoi ne pas utiliser resul par exemple ou resultat?)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    int fact(int n){
        int i, j;
        j = 1; /* j n'est pas un nom terrible ici: habituellement utilisé comme indice de boucle */
        for (i = 1; i<=n; i++) { /* attention '=' n'est pas '==' */
            j = j * i;
        }
        return j;  /* C'est j que tu dois renvoyer, mais pas n;*/
    }
    Bonne chance

    Thierry
    "The most important thing in the kitchen is the waste paper basket and it needs to be centrally located.", Donald Knuth
    "If the only tool you have is a hammer, every problem looks like a nail.", probably Abraham Maslow

    FAQ-Python FAQ-C FAQ-C++

    +

  7. #7
    Expert confirmé
    Avatar de krachik
    Inscrit en
    Décembre 2004
    Messages
    1 964
    Détails du profil
    Informations forums :
    Inscription : Décembre 2004
    Messages : 1 964
    Points : 4 015
    Points
    4 015
    Par défaut
    bonjour
    bien sur apres tu peux t'amuser a faire de petits tests sur n
    par exemple si n est négatif
    avec une iteration par exemple tu n'a pas besoin de faire le teste pour n=0;mais
    avec une recursivité tu es obligé de faire diferent test(exemple n=0) et apres pour n<0;
    bon courage.
    Je suis ce que je suis grâce à ce que nous sommes tous Humanité aux Humains!! !

    Entre ce que je pense, ce que je veux dire, ce que je crois dire, ce que je dis ce que vous avez envie d'entendre, ce que vous croyez entendre, ce que vous entendez, ce que vous avez envie de comprendre, ce que vous comprenez ... Il y a dix possibilités que nous ayons des difficultés à communiquer. Mais essayons quand meme ....... E. Wells

  8. #8
    Rédacteur
    Avatar de Franck.H
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Janvier 2004
    Messages
    6 951
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Haut Rhin (Alsace)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Service public

    Informations forums :
    Inscription : Janvier 2004
    Messages : 6 951
    Points : 12 462
    Points
    12 462
    Par défaut
    Citation Envoyé par krachik
    bonjour
    bien sur apres tu peux t'amuser a faire de petits tests sur n
    par exemple si n est négatif
    avec une iteration par exemple tu n'a pas besoin de faire le teste pour n=0;mais
    avec une recursivité tu es obligé de faire diferent test(exemple n=0) et apres pour n<0;
    bon courage.
    Mouais, si c'est juste les tests qui te poses des soucis d'esthétique ... la récursivité une façon plus esthétique pour résoudre ce genre de problèmes (calcul factoriel entre autre chose, parcours d'arbres, etc...).
    Mon Site
    Ma bibliothèque de gestion des chaînes de caractères en C

    L'imagination est plus importante que le savoir. A. Einstein

    Je ne répond à aucune question technique par MP, merci d'avance !

  9. #9
    Membre régulier
    Profil pro
    Étudiant
    Inscrit en
    Novembre 2006
    Messages
    114
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2006
    Messages : 114
    Points : 75
    Points
    75
    Par défaut
    ééé oui, j'ai bien pris ma leçon..
    merci pour vous tous.

  10. #10
    Expert confirmé
    Avatar de Thierry Chappuis
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Mai 2005
    Messages
    3 499
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Suisse

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 499
    Points : 5 360
    Points
    5 360
    Par défaut
    Citation Envoyé par Franck.H
    Mouais, si c'est juste les tests qui te poses des soucis d'esthétique ... la récursivité une façon plus esthétique pour résoudre ce genre de problèmes (calcul factoriel entre autre chose, parcours d'arbres, etc...).
    La récursivité peut toutefois causer quelques soucis. J'ai bien aimé ton tutoriel et notamment la partie consacrée à la récursivité terminale (utilisation plus contrôlée de la pile). Toutefois, dans le cas du calcul d'une factorielle, je recommande la méthode itérative, qui dans ce cas précis n'est pas moins lisible. La situation est différente lorsqu'il s'agit de parcourir un arbre.

    Thierry
    "The most important thing in the kitchen is the waste paper basket and it needs to be centrally located.", Donald Knuth
    "If the only tool you have is a hammer, every problem looks like a nail.", probably Abraham Maslow

    FAQ-Python FAQ-C FAQ-C++

    +

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

Discussions similaires

  1. script samba qui calcule le factoriel d'un nombre entier
    Par miryam22 dans le forum Shell et commandes GNU
    Réponses: 2
    Dernier message: 30/05/2008, 10h00
  2. Codage C++ de Factoriel d'un nombre entier
    Par theserialkiller10 dans le forum C++
    Réponses: 23
    Dernier message: 24/10/2007, 16h50
  3. Prog pour calculer la factorielle d'un nombre
    Par Lenezir dans le forum Langage
    Réponses: 2
    Dernier message: 11/05/2007, 09h42
  4. Calcul de la factorielle d'un nombre naturel
    Par Sadgunner dans le forum Pascal
    Réponses: 9
    Dernier message: 20/06/2006, 21h56
  5. factoriel d'un nombre
    Par etoile1506 dans le forum C
    Réponses: 10
    Dernier message: 03/12/2005, 15h46

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