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 :

Probleme de calcul


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Septembre 2006
    Messages
    24
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 24
    Par défaut Probleme de calcul
    Bonjour,
    J'ai a faire a un petit probleme de calcul. Voici tout d'abord le code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    double fNumber;
    __int64 nNumber = (__int64)(fNumber * (pow((double)10, 2)));
    	fNumber = (double)nNumber / (pow((double)10, 2));
    Le souci c'est que si fNumber = 0.28999...le resultat de tout ca sera 0.28,
    mais si fNumber = 0.489999... j'obtiens 0.49.
    Normalement le résultat attendu par l'utilisateur doit etre 0.29 et non 0.28.
    Merci pour votre aide !
    Sarah

  2. #2
    Membre confirmé Avatar de O( N )
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juillet 2006
    Messages
    126
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juillet 2006
    Messages : 126
    Par défaut
    Bonjour

    Je voudrais savoir si tu es obligé de faire
    pow((double)10,2) et non 100 directement.
    Tout calcul superflus peut faire perdre en qualité (il me semble)

    Pour les problèmes de transtypage (cast en anglais)
    je te conseille de vérifier la validité du transtypage
    de ton code à ta ligne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    __int64 nNumber = (__int64)fNumber;
    Puis en réalisant l'inverse, cela pourrait te donner des indications si le problème venait d'ici.

    Je ne te donne pas de code mais juste des tests de validation car je ne suis pas un trés grand connaisseur des problèmes liés au transtypage.

  3. #3
    Membre averti
    Inscrit en
    Septembre 2006
    Messages
    24
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 24
    Par défaut
    Je voudrais savoir si tu es obligé de faire
    pow((double)10,2) et non 100 directement.
    Oui car dans le code initial a la place de 2 j'ai une variable dont les clients peuvent fixer la valeur si ils le veulent
    par contre pour ce qui est de ton test, je ne comprend pas trop
    Pour moi aussi toutes ces trucs c'est un peu nouveau mais ce bug doit etre fixé donc je my colle ....

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

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par Sarkou
    Le souci c'est que si fNumber = 0.28999...le resultat de tout ca sera 0.28,

    Normalement le résultat attendu par l'utilisateur doit etre 0.29 et non 0.28.
    Problème d'arrondi. C'est une .

    Nota : __int64, n'est pas standard. En C99, il y a long long qui fait au moins 64 bits.

  5. #5
    Membre averti
    Inscrit en
    Septembre 2006
    Messages
    24
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 24
    Par défaut
    Problème d'arrondi.
    Je fais une troncature pas un arrondi...est ce que le code n'est pas bon ?
    J'avoue que je suis un peu perdue pour le coup...

  6. #6
    Membre averti
    Inscrit en
    Septembre 2006
    Messages
    24
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 24
    Par défaut
    Coucou
    Voila finalement la solution que j'ai prise et qui a l'air de marcher pas mal:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    __int64 nNumber = (__int64)(ceil(fNumber * (pow((double)10, 5))));
    		fNumber = ((double) nNumber) / (pow((double)10, 5));
    Bye !

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

Discussions similaires

  1. [FLASH 8] Problemes de calcul précis avec FLASH
    Par ZecMan dans le forum Flash
    Réponses: 1
    Dernier message: 20/02/2006, 14h03
  2. Probleme de calcul :S
    Par vodevil dans le forum Langage
    Réponses: 2
    Dernier message: 22/12/2005, 20h06
  3. probleme de calculs : 1-0.9 = 0.099999999999998
    Par francon81 dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 30/06/2005, 14h17
  4. Petit probleme de calcul...
    Par Mistoufline dans le forum Algorithmes et structures de données
    Réponses: 18
    Dernier message: 17/05/2005, 16h52
  5. [Conversion]Probleme de calcul en double et en floatant
    Par TOPGUN89 dans le forum Général Java
    Réponses: 2
    Dernier message: 18/04/2005, 17h46

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