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 :

la fonction getDecimal retourne 0. Je sais pas pourquoi.


Sujet :

C++

  1. #1
    Débutant
    Homme Profil pro
    aucun
    Inscrit en
    Avril 2012
    Messages
    152
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Avril 2012
    Messages : 152
    Points : 28
    Points
    28
    Par défaut la fonction getDecimal retourne 0. Je sais pas pourquoi.
    Bonjour,

    Je suis un débutant en c++. Je travaille avec c++ depuis 1 mois à l'aide de poo. Il y a un problème dans ma fonction(getDecimal) parce que ça retourne toujours 0.

    fraction.h
    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
    #ifndef FRACTION_H
    #define FRACTION_H
    #include <iostream>
    #include <string>
    using namespace std;
     
    class fraction
    {
    private:
    	int m_numerateur;
    	int m_denominateur;
     
    public:
    	fraction(int arg1 = 0,int arg2 = 1);
    	int getDenominateur() const;
    	int getNumerateur() const;
    	void setDenominateur(int x);
    	void setNumerateur(int x);
    	void getFraction() const;
    	double getDecimal() const;
    };
    #endif
    head.h
    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
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    #include <iostream>
    #include "fraction.h"
    using namespace std;
     
    fraction::fraction(int arg1,int arg2)
    {
    	m_numerateur = arg1;
    	m_denominateur = arg2;
    }
     
    int fraction::getDenominateur() const
    {
    	return m_denominateur;
    }
     
    int fraction::getNumerateur() const
    {
    	return m_numerateur;
    }
     
    void fraction::setNumerateur(int x)
    {
    	m_numerateur = x;
    }
     
    void fraction::setDenominateur(int x)
    {
    	m_denominateur = x;
    }
     
    void fraction::getFraction() const
    {
    	cout << m_numerateur << "/" << m_denominateur;
    }
     
    void calculer(fraction &arg1,string arg2,fraction &arg3)
    {
    	fraction resultat;
    	int dc;
    	int n1;
    	int n2;
    	int d2;
    	int nt;
    	if(arg2 == "+")
    	{
    		if(arg1.getDenominateur() != arg3.getDenominateur())
    		{
    			dc = arg1.getDenominateur() * arg3.getDenominateur();
    			n1 =  arg1.getNumerateur() * arg3.getDenominateur();
    			n2 =  arg3.getNumerateur() * arg1.getDenominateur();
    			nt = n1 + n2;
    			resultat.setNumerateur(nt);
    			resultat.setDenominateur(dc);
    			resultat.getFraction();
    		}
    		else
    		{
    			nt = arg1.getNumerateur() + arg3.getNumerateur();
    			resultat.setNumerateur(nt);
    			resultat.setDenominateur(arg1.getDenominateur());
    			resultat.getFraction();
    		}
    	}
    		if(arg2 == "-")
    	{
    		if(arg1.getDenominateur() != arg3.getDenominateur())
    		{
    			dc = arg1.getDenominateur() * arg3.getDenominateur();
    			n1 =  arg1.getNumerateur() * arg3.getDenominateur();
    			n2 =  arg3.getNumerateur() * arg1.getDenominateur();
    			nt = n1 - n2;
    			resultat.setNumerateur(nt);
    			resultat.setDenominateur(dc);
    			resultat.getFraction();
    		}
    		else
    		{
    			nt = arg1.getNumerateur() - arg3.getNumerateur();
    			resultat.setNumerateur(nt);
    			resultat.setDenominateur(arg1.getDenominateur());
    			resultat.getFraction();
    		}
    	}
    	if(arg2 == "*")
    	{
    		nt = arg1.getNumerateur() * arg3.getNumerateur();
    		dc = arg1.getDenominateur() * arg3.getDenominateur();
    		resultat.setNumerateur(nt);
    		resultat.setDenominateur(dc);
    		resultat.getFraction();
    	}
    	if(arg2 == "/")
    	{
    		n2 = arg3.getDenominateur();
    		d2 = arg3.getNumerateur();
    		nt = arg1.getNumerateur() * n2;
    		dc = arg1.getDenominateur() * d2;
    		resultat.setNumerateur(nt);
    		resultat.setDenominateur(dc);
    		resultat.getFraction();
    	}
    }
     
    double fraction::getDecimal() const
    {
    	return m_numerateur / m_denominateur;
    }
    training.cpp
    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
    #include <iostream>
    #include "head.h"
    using namespace std;
     
    int main()
    {
    	fraction a(2,5);
    	fraction b(3,4);
    	cout << a.getDecimal();
    	cout << endl;
    	if(a.getDecimal() > b.getDecimal())
    	{
    		a.getFraction(); 
    		cout << " est plus grand que ";
    		b.getDecimal(); 
    		cout << endl;
    	}
    	else if(a.getDecimal() < b.getDecimal())
    	{
    		b.getFraction(); 
    		cout << " est plus grand que ";
    		a.getDecimal(); 
    		cout << endl;
    	}
    	system("pause");
    	return 0;
    }

  2. #2
    Inactif  


    Homme Profil pro
    Inscrit en
    Novembre 2008
    Messages
    5 288
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Secteur : Santé

    Informations forums :
    Inscription : Novembre 2008
    Messages : 5 288
    Points : 15 617
    Points
    15 617
    Par défaut
    Bonjour

    PilloBuenaGente t'a déjà signalé ce problème. Relis les anciennes discussions

  3. #3
    Débutant
    Homme Profil pro
    aucun
    Inscrit en
    Avril 2012
    Messages
    152
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Avril 2012
    Messages : 152
    Points : 28
    Points
    28
    Par défaut
    Merci. Je n'avais pas vu. Je suis vraiment désolé.

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

    Informations professionnelles :
    Activité : aucun

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

    De plus, une fonction "get" qui ne renvoie rien est, a priori, suspecte.

    On pourrait, déjà, pinailler sur le choix de placer des mutateurs sur une fraction, car ca semble en contradiction avec la sémantique de valeur (par contre, des opérateurs mathématiques comme +, -, *, et / pourraient être intéressant), mais, forcer le fait que getFraction renvoie, sommes toutes, une chaine de caractères sur la sortie standard ne me semble vraiment pas opportun:
    • Il semble dommage de te limiter au seul flux vers la sortie standard
    • Tu places une dépendance qui t'interdira de faire évoluer ton application en rajoutant une interface graphique par la suite
    Personnellement, j'envisagerais plutôt la surcharge de l'opérateur de flux "<<", en veillant à ce qu'il puisse s'adapter à "n'importe quel flux envisageable".

    Il faut, en effet, savoir que tous les flux de sorties (qu'il s'agisse de fichier, de flux de conversion ou de la sortie standard) héritent de std::ostream et qu'il serait donc tout à fait possible de faire en sorte que le comportement soit similaire, avec un code proche de
    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
     
    class fraction
    {
    private:
    	int m_numerateur;
    	int m_denominateur;
     
    public:
         std::ostream & operator << (std::ostream & os) const
         {
             os<<m_numerateur <<" / " <<n_denominateur;
             return os;
         }
         /* tout le reste sauf getFraction ;) */
    };

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

Discussions similaires

  1. [Oracle] impossible d'insérer et je ne sais pas pourquoi
    Par sajedose dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 25/03/2008, 15h25
  2. Cargo - Ca fonctionne mais je ne sais pas pourquoi.
    Par RémyYves dans le forum Maven
    Réponses: 1
    Dernier message: 07/02/2008, 14h13
  3. j'ai une erreur à l'execution de ce code je ne sais pas pourquoi
    Par jack_1981 dans le forum VB 6 et antérieur
    Réponses: 15
    Dernier message: 28/01/2008, 12h29
  4. je ne sais pas pourquoi ce code ca marche pas
    Par debutantasp dans le forum ASP
    Réponses: 14
    Dernier message: 23/11/2007, 18h10

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