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 :

Multiplication d'un entier avec un décimal ?


Sujet :

C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Profil pro
    Inscrit en
    Février 2009
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2009
    Messages : 2
    Par défaut Multiplication d'un entier avec un décimal ?
    Bonjour,

    m'y connaissant pas trop, je voulais savoir si on pouvait multiplier un entier avec un décimal, et si oui, quel est le code à utiliser ?

    Merci.

  2. #2
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2009
    Messages
    68
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2009
    Messages : 68
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    int entier = 2;
    float decimal = 2.5;
    float resultat = entier * decimal;
    Le résultat d'une multiplication entre un int et un float est un float

  3. #3
    Nouveau candidat au Club
    Profil pro
    Inscrit en
    Février 2009
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2009
    Messages : 2
    Par défaut
    Merci beaucoup, en fait, j'utilisais la virgule au lieu du point.

  4. #4
    r0d
    r0d est déconnecté
    Membre expérimenté

    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    4 290
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2004
    Messages : 4 290
    Billets dans le blog
    2
    Par défaut
    Bonjour,

    Si je puis me permettre d'ajouter un paire de remarques:
    Tout d'abord, en vérité cela va dépendre du type du résultat. Ensuite, je conseille toujours, dans ce cas, de spéficier explicitement le cast:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    int entier = 2;
    float decimal = 2.5f;
    float resultatFlottant = (float) entier * decimal;
    int resultatEntier = entier * (int) decimal;
    D'ailleurs tout bon comilateur bien réglé donnera un warning à la compilation si on ne spécifie pas explicitement le cast. Le cast explicite permet une lecture plus claire du code: on voit mieux ce que le développeur (souvent nous-même quand on doit modifier ou relire notre propre code) a voulu faire. Et dans certains cas un peu complexe, ça aide le compilateur à optimiser ou même à savoir ce qu'il faut faire.

  5. #5
    Expert confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2003
    Messages
    3 549
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Décembre 2003
    Messages : 3 549
    Par défaut
    Le résultat d'une multiplication entre un int et un float est un float
    C'est pas plutôt un double ?

  6. #6
    Expert confirmé

    Inscrit en
    Novembre 2005
    Messages
    5 145
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 5 145
    Par défaut
    Citation Envoyé par Veeed Voir le message
    Bonjour,

    m'y connaissant pas trop, je voulais savoir si on pouvait multiplier un entier avec un décimal, et si oui, quel est le code à utiliser ?

    Merci.
    Si tu veux des decimaux, il faut te les fabriquer ou trouver une bibliotheque deja existante. Les flottants sont rarement decimaux (en fait je n'ai jamais entendu parler d'une implementation de C++ qui avait des float decimaux; mais il y a un TR en cours pour ca et le TR correspondant pour le C est deja passe).

    Citation Envoyé par loufoque Voir le message
    C'est pas plutôt un double ?
    Non. En C pre-norme c'etait bien le cas et il y a toujours une lattitude pour utiliser des formats plus precis pour les calculs intermediaires -- ce qui est plutot genant quand on cherche a controler les arrondis precisement.

  7. #7
    Expert confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2003
    Messages
    3 549
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Décembre 2003
    Messages : 3 549
    Par défaut
    Ah oui, en effet.
    Ce genre de promotions c'est que pour les entiers.

    il y a toujours une lattitude pour utiliser des formats plus precis pour les calculs intermediaires -- ce qui est plutot genant quand on cherche a controler les arrondis precisement.
    Il y a des conséquences pires.
    std::set<std::pair<float, int>> ne marche pas à cause de ça. L'un des flottants peut être inférieur à l'autre avec une grande précision mais ils peuvent être égaux en précision normale.
    Pour std::set<float>, par contre, ça marche quand même.

Discussions similaires

  1. [Toutes versions] Format avec deux décimales et virgule sans zéro, sauf pour les entiers
    Par Invité dans le forum Excel
    Réponses: 4
    Dernier message: 06/03/2014, 01h23
  2. Multiplication php avec 2 décimales
    Par crg227 dans le forum Langage
    Réponses: 4
    Dernier message: 29/03/2011, 08h15
  3. Réponses: 4
    Dernier message: 04/03/2010, 10h04
  4. [debutant][jsp]Passage d'entier avec une session sans cookie
    Par o151181 dans le forum Servlets/JSP
    Réponses: 5
    Dernier message: 04/02/2004, 18h22
  5. Requete avec des décimales
    Par Sandrine75 dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 27/06/2003, 10h18

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