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 :

Aide Fonction factorielle


Sujet :

C++

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Août 2010
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Août 2010
    Messages : 12
    Par défaut Aide Fonction factorielle
    Voilà, je fais actuellement ma première fonction, qui est une fonction qui donne la factorielle d'un nombre. J'y arrive a peu près, mais j'ai deux problèmes:

    1) Je n'arrive pas à faire en sorte que le programme écrive "La factorielle de x est y".

    2) Quand j'écris une lettre au lieu d'un nombre, le programme m'écrit en boucle "Entrez un nombre en 0 et 255 : Ce nombre est invalide"

    Voici 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
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    // Factorielle.cpp*: définit le point d'entrée pour l'application console.
    //
     
    #include "stdafx.h"
     
     
    int main(void)
    {
    	unsigned int x, y=1;
    	printf("Calcul de la factorielle\n");
    	negatif:;
    	printf("Entrez un nombre entre 0 et 255 : ");
    	scanf("%i",&x);
    	if(x>255) printf("Ce nombre est invalide.\n");
    	if(x>255) goto negatif;
    	while(x>1)
    	{
    		y=x*y;
    		x=x-1;
    	}
    	printf("La factorielle de &i est &i.\n", x, y);
    	goto negatif;
    	return 0;
    }

  2. #2
    Membre Expert
    Homme Profil pro
    Chercheur
    Inscrit en
    Mars 2010
    Messages
    1 218
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Chercheur

    Informations forums :
    Inscription : Mars 2010
    Messages : 1 218
    Par défaut
    Bonsoir,

    tu n'es pas dans le bon forum : ton code est écrit en C.
    Petit conseil personnel : fais rapidement disparaître les "goto" de ton algorithme avant de poster ton code autre part...

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Août 2010
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Août 2010
    Messages : 12
    Par défaut
    D'accord mais quelles sont les caractéristiques qui font que ce code est écrit en C plutôt qu'en C++?
    Parce que c'est un devoir, et je dois l'écrire en C++, et je suis un tutoriel qui fait le C et le C++ en "parallèle"...
    Sinon pour le goto j'ai cherché une autre chose qui pourrait faire sauter la fonction while mais je n'ai pas trouvé...

  4. #4
    Expert éminent
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 644
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 644
    Par défaut
    Salut,
    Citation Envoyé par Bibibis Voir le message
    D'accord mais quelles sont les caractéristiques qui font que ce code est écrit en C plutôt qu'en C++?
    Parce que c'est un devoir, et je dois l'écrire en C++, et je suis un tutoriel qui fait le C et le C++ en "parallèle"...
    Sinon pour le goto j'ai cherché une autre chose qui pourrait faire sauter la fonction while mais je n'ai pas trouvé...
    En gros, les fonctions printf, scanf et consort sont des fontions de C.

    Si elle sont présentes en C++, ce n'est que dans un soucis de comptabilité, mais il est globalement déconseillé d'y recourir en C++.

    En C++, printf sera remplacé par l'utilisation de cout et scanf par celle de cin (tous deux présents dans l'espace de noms std par inclusion du fichier d'en-tête <iostream>)

    Ceci dit, tu devrais essayer de réfléchir à l'utilisation de goto... Sauf cas particulier est excessivement rare en C++, tu devrais préférer l'utilisation des différents types de boucles à celle de goto
    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

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Août 2010
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Août 2010
    Messages : 12
    Par défaut
    Voilà j'ai réussi à supprimer le code C et ça marche, j'ai juste un problème: quand je met une lettre au lieu d'un nombre le programme met
    "La factorielle de 0 est 1"
    "La factorielle de 0 est 1"
    "La factorielle de 0 est 1"
    ...

    Et je ne sais pas pourquoi.

    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
    // Factorielle.cpp*: définit le point d'entrée pour l'application console.
    //
     
    #include <StdAfx.h>
    #include <iostream>
     
     
    int main(void)
    {
    	std::cout << "Calcul de la factorielle" << std::endl;
    	negatif:;
    	unsigned int x=0, y=1, n=0;
    	std::cout << "Entrez un nombre entre 0 et 30 : ";
    	std::cin >> x;
    	n=x;
    	if(x>30) printf("Ce nombre est invalide.\n");
    	if(x>30) goto negatif;
    	while(x>1)
    	{
    		y=x*y;
    		x=x-1;
    	}
    	std::cout << "La factorielle de " << n << " est " << y << std::endl;
    	goto negatif;
    	return 0;
    }

  6. #6
    Membre Expert
    Homme Profil pro
    Chercheur
    Inscrit en
    Mars 2010
    Messages
    1 218
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Chercheur

    Informations forums :
    Inscription : Mars 2010
    Messages : 1 218
    Par défaut
    Bonsoir,

    c'est l'avant denière ligne de ton code
    qui renvoie au début de ton code qui explique ce comportement.

  7. #7
    Expert confirmé

    Inscrit en
    Août 2006
    Messages
    3 969
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 3 969
    Par défaut
    Kai,

    Pourquoi persister avec ces ... de goto ?

    Il y a différentes formes de boucles, ça fait partie des bases à apprendre très rapidement.

  8. #8
    Membre averti
    Profil pro
    Inscrit en
    Août 2010
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Août 2010
    Messages : 12
    Par défaut
    Oui je veux supprimer ces goto, mais j'essaie avant tout de faire un truc qui fonctionne. Maintenant que ça marche je vais m'atteler à supprimer les goto, je voulais enlever le bug que j'ai cité avant, mais vu que c'est les goto qui le générent je vais les supprimer.

    Je vais reposter un code sans les goto ce soir quand je serai rentré chez moi et que j'aurai pu voir mon code et le rendre mieux.

  9. #9
    Membre Expert
    Homme Profil pro
    Chercheur
    Inscrit en
    Mars 2010
    Messages
    1 218
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Chercheur

    Informations forums :
    Inscription : Mars 2010
    Messages : 1 218
    Par défaut
    Bonjour,

    à titre d'exercice, tu peux essayer de coder le calcul des factorielles de manière récursive : c'est un exemple classique pour introduire la récursivité normalement.

  10. #10
    Expert éminent
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 644
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 644
    Par défaut
    Citation Envoyé par Bibibis Voir le message
    Oui je veux supprimer ces goto, mais j'essaie avant tout de faire un truc qui fonctionne. Maintenant que ça marche je vais m'atteler à supprimer les goto, je voulais enlever le bug que j'ai cité avant, mais vu que c'est les goto qui le générent je vais les supprimer.

    Je vais reposter un code sans les goto ce soir quand je serai rentré chez moi et que j'aurai pu voir mon code et le rendre mieux.
    Le fait est que tu devrais t'habituer le plus rapidement possible à réfléchir à la logique que tu veux mettre en place avant d'écrire la première ligne de code.

    Le gros du travail se fait avec un morceau de papier et un bout de crayon (du moins, si on utilise une *bonne* manière pour représenter la logique )

    Avec la bonne méthode, il est tout à fait possible de ne jamais être tenté d'utiliser goto (Ce qui est préférable quand on a un prof qui menace de nous virer par la fenêtre si on l'utilise... et qui en est capable )
    Citation Envoyé par Aleph69 Voir le message
    Bonjour,

    à titre d'exercice, tu peux essayer de coder le calcul des factorielles de manière récursive : c'est un exemple classique pour introduire la récursivité normalement.
    Oui, mais non...

    La factorielle (tout comme l'exponentielle d'ailleurs) est typiquement un contre exemple qui me fait se dresser tous les poils sur le corps quand je le rencontre dans un cours ou un tutorial au chapitre de la récursivité

    Imagine un peu: c'est comme si on te laissait rouler à gauche pendant tout ton apprentissage du permis de conduire puis que, la veille de l'examen, on te disait "au fait, faut rouler à droite"

    Mais bon, le problème n'est pas là
    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

  11. #11
    Expert confirmé

    Inscrit en
    Août 2006
    Messages
    3 969
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 3 969
    Par défaut
    Hoa,
    Citation Envoyé par koala01 Voir le message
    Avec la bonne méthode, il est tout à fait possible de ne jamais être tenté d'utiliser goto (Ce qui est préférable quand on a un prof qui menace de nous virer par la fenêtre si on l'utilise... et qui en est capable )
    Oui, mais non...

    La factorielle (tout comme l'exponentielle d'ailleurs) est typiquement un contre exemple qui me fait se dresser tous les poils sur le corps quand je le rencontre dans un cours ou un tutorial au chapitre de la récursivité
    C'est un des trucs que je me tue à dire, répéter, et re-répéter ...

    Rien à faire, c'est un exemple tellement classique que nombre d'enseignants n'y réfléchissent plus, et le traitent comme "on a toujours fait ainsi" ...

    Après, on s'étonne de voir de la récursivité partout, y compris quand son usage est une stupidité totale.

  12. #12
    Membre Expert
    Homme Profil pro
    Chercheur
    Inscrit en
    Mars 2010
    Messages
    1 218
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Chercheur

    Informations forums :
    Inscription : Mars 2010
    Messages : 1 218
    Par défaut
    Pourquoi est-ce un mauvais exemple pour introduire la récursivité?

  13. #13
    Membre chevronné Avatar de seeme
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    430
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France

    Informations forums :
    Inscription : Octobre 2005
    Messages : 430
    Par défaut
    Citation Envoyé par droggo Voir le message
    Hoa,

    C'est un des trucs que je me tue à dire, répéter, et re-répéter ...

    Rien à faire, c'est un exemple tellement classique que nombre d'enseignants n'y réfléchissent plus, et le traitent comme "on a toujours fait ainsi" ...

    Après, on s'étonne de voir de la récursivité partout, y compris quand son usage est une stupidité totale.

    En même temps, le but c'est pas d'apprendre à coder une fonction factoriel... Mais la fonction se prête bien à l'illustration du principe de récursivité

    Mes profs m'ont jamais dit que c'était comme ça qu'il fallait faire la factorielle

  14. #14
    Expert éminent
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 644
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 644
    Par défaut
    Citation Envoyé par Aleph69 Voir le message
    Pourquoi est-ce un mauvais exemple pour introduire la récursivité?
    Parce qu'une simple boucle bien étudiée fait tout aussi bien le boulot

    Il y a deux raisons principales qui font que la récursivité ait mauvaise réputation:

    1- Le fait que, trop souvent, les gens ne savent simplement pas comment faire pour en sortir, et qu'ils passent des heures à s'arracher les cheveux en se demandant comment faire... Quand on pense qu'il suffit de tester le cas de base et de veiller à ce que le reste de la logique tende vers lui

    2- La récursivité utilisée à mauvais escient (comprend: quand une boucle pourrait faire l'affaire) présente de nombreux inconvénients dont un sérieux ralentissement du traitement (mine de rien, cela prend un temps bête d'empiler et de dépiler les appels ) et un risque accru (bien que les technologie tendent à l'éloigner de plus en plus) de dépassement de pile... Le fameux Stack overflow que tout le monde redoute arrive beaucoup plus facilement avec une fonction récursive qu'avec une boucle
    Citation Envoyé par seeme Voir le message
    En même temps, le but c'est pas d'apprendre à coder une fonction factoriel... Mais la fonction se prête bien à l'illustration du principe de récursivité
    Si tu veux exposer le principe de la récursivité, rien ne vaut le problème des "tours de Hannoï" qui serait un véritable casse-tête à essayer de résoudre avec des boucles
    Mes profs m'ont jamais dit que c'était comme ça qu'il fallait faire la factorielle
    Et ils ont eu [EDIT] non bien tord mais bien raison... j'avais "sauté un mot [/EDIT]...

    La récursivité est nécessaire dans un certain nombre de situation, comme la résolution du problème des tours de hannoï ou le parcours en profondeur d'un arbre (binaire ou quelconque), mais la factorielle et l'exponentielle sont tellement facile à calculer sur une simple boucle

    Le seul cas particulier pour lequel j'envisagerais la récursivité sur ces deux fonctions serait la nécessité de faire en sorte que le compilateur calcule tout cela une bonne fois pour toutes, et je le ferais à base de template (mais, là, on entre vraiment dans un cas à part )
    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

  15. #15
    Membre Expert
    Homme Profil pro
    Chercheur
    Inscrit en
    Mars 2010
    Messages
    1 218
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Chercheur

    Informations forums :
    Inscription : Mars 2010
    Messages : 1 218
    Par défaut
    Citation Envoyé par koala01 Voir le message
    Il y a deux raisons principales qui font que la récursivité ait mauvaise réputation:

    1- Le fait que, trop souvent, les gens ne savent simplement pas comment faire pour en sortir, et qu'ils passent des heures à s'arracher les cheveux en se demandant comment faire... Quand on pense qu'il suffit de tester le cas de base et de veiller à ce que le reste de la logique tende vers lui

    2- La récursivité utilisée à mauvais escient (comprend: quand une boucle pourrait faire l'affaire) présente de nombreux inconvénients dont un sérieux ralentissement du traitement (mine de rien, cela prend un temps bête d'empiler et de dépiler les appels ) et un risque accru (bien que les technologie tendent à l'éloigner de plus en plus) de dépassement de pile... Le fameux Stack overflow que tout le monde redoute arrive beaucoup plus facilement avec une fonction récursive qu'avec une boucle
    Donc... la factorielle est un bon exemple!
    Tu introduis la technique et tu en montres les limites.

  16. #16
    Expert éminent
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 644
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 644
    Par défaut
    Citation Envoyé par Aleph69 Voir le message
    Donc... la factorielle est un bon exemple!
    Tu introduis la technique et tu en montres les limites.
    C'est un très mauvais exemple, au contraire...

    De combien devra tu calculer la factorielle avant d'atteindre, effectivement, les limites du processeur

    Tu auras dépassé au minimum trois fois la valeur maximale du type le plus grand avant d'y arriver

    Il faudrait, pour avoir une chance d'arriver aux limites du processeur, un exemple de double récursivité, ce qui ne se trouve malgré tout pas tous les jours

    Finalement, tu as beaucoup plus de chances d'atteindre les limites avec... le parcours en profondeur d'un arbre ou en demandant de résoudre les tours de hannoï avec 64 palets (mais bon, tu risque d'attendre la fin du travail pendant un temps certain )
    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

  17. #17
    Membre Expert
    Homme Profil pro
    Chercheur
    Inscrit en
    Mars 2010
    Messages
    1 218
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Chercheur

    Informations forums :
    Inscription : Mars 2010
    Messages : 1 218
    Par défaut
    Citation Envoyé par koala01 Voir le message
    De combien devra tu calculer la factorielle avant d'atteindre, effectivement, les limites du processeur
    Je viens de tester : j'ai un stack overflow pour n=99999;
    Je n'ai même pas eu le temps de respirer avant de provoquer l'erreur et je suis en mode debug...
    Ceci dit, je suis d'accord que la version récursive de DFS est aussi un bon exemple.

  18. #18
    Membre Expert
    Avatar de Joel F
    Homme Profil pro
    Chercheur en informatique
    Inscrit en
    Septembre 2002
    Messages
    918
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Chercheur en informatique
    Secteur : Service public

    Informations forums :
    Inscription : Septembre 2002
    Messages : 918
    Par défaut
    just en passant, les bons compilos modernent savent derecursifier des appels tail-recursives.

  19. #19
    Expert éminent
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 644
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 644
    Par défaut
    Parce que, pour toi, près de cent mille appels, ce n'est rien

    Il est vrai qu'avec les bécanes actuellles, cela semble aller vite, mais, si tu effectuait un certain nobmre de fois le même travail avec une boucle et que tu le chronométrais, puis que tu comparais le temps mis sur le travail basé sur la boucle avec celui basé sur la récursivité, tu verrais une différence assez importante
    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

  20. #20
    Membre Expert
    Homme Profil pro
    Chercheur
    Inscrit en
    Mars 2010
    Messages
    1 218
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Chercheur

    Informations forums :
    Inscription : Mars 2010
    Messages : 1 218
    Par défaut
    Citation Envoyé par Joel F Voir le message
    just en passant, les bons compilos modernent savent derecursifier des appels tail-recursives.
    Tiens, il faudra que j'essaie!
    Ma dernière expérience remonte à Visual 6 et il ne le faisait pas pour DFS.
    A moins qu'il faille spécifier une option supplémentaire par rapport aux classiques O2 & Cie?

+ Répondre à la discussion
Cette discussion est résolue.
Page 1 sur 3 123 DernièreDernière

Discussions similaires

  1. aide fonction tri heapsort (création du tas)
    Par Invité dans le forum C
    Réponses: 6
    Dernier message: 24/11/2009, 00h27
  2. [aide fonction popup.close() ]
    Par viny dans le forum Général JavaScript
    Réponses: 6
    Dernier message: 17/07/2006, 16h41
  3. Aide fonction getopt
    Par makohsarah dans le forum C
    Réponses: 12
    Dernier message: 12/06/2006, 16h02
  4. aide fonction math[racine,cos(),sin(),..]VB6
    Par am.adnane dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 28/12/2005, 18h40
  5. besoin d'aide fonction avec fichier (debutant)
    Par boby61 dans le forum Débuter
    Réponses: 9
    Dernier message: 14/03/2005, 11h22

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