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 :

Précision pour un double


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Octobre 2008
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Octobre 2008
    Messages : 13
    Par défaut Précision pour un double
    Bonjour j'ai un problème avec la précision d'un double. Il s'agit de regarder ce code. Pouvez-vous m'aider ??

    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
    #include <stdio.h>
    #include <stdlib.h>
    #include <math.h>
     
    int main(void)
    {
    double var;
    double res;
     
    var = 1111111111122;
    res = var / pow(10,2);
     
    printf("%lf",res);
    // le resultat on obtient 11111111111.219999 Alors que j'aimerai obtenir 11111111111.220000
     
    return 0;
    }

  2. #2
    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 weis3r Voir le message
    Bonjour j'ai un problème avec la précision d'un double. Il s'agit de regarder ce code. Pouvez-vous m'aider ??

    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
    #include <stdio.h>
    #include <stdlib.h>
    #include <math.h>
     
    int main(void)
    {
    double var;
    double res;
     
    var = 1111111111122;
    res = var / pow(10,2);
     
    printf("%lf",res);
    // le resultat on obtient 11111111111.219999 Alors que j'aimerai obtenir 11111111111.220000
     
    return 0;
    }
    Les nombres réels sont codés en virgule flottante (signe+mantisse+exposant). ce sont des valeurs dont la précision n'est pas infinie. Il est normal que l'affichage montre les erreurs de précision.

    Néanmoins, on peut jouer avec la précision de l'&ffichage qui fait des arrondis :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    #include <stdio.h>
    #include <math.h>
     
    int main (void)
    {
       double var = 1111111111122.;
       double res = var / pow (10, 2);
     
       printf ("%.2f\n", res);
     
       return 0;
    }
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    11111111111.22
     
    Process returned 0 (0x0)   execution time : 0.035 s
    Press any key to continue.

  3. #3
    Membre averti
    Inscrit en
    Octobre 2008
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Octobre 2008
    Messages : 13
    Par défaut Oui mais !
    Je suis d'accord mais je veux récupérer cette valeur pour traitement avec une autre variable. Si je n'ai pas la valeur exacte ça ne fonctionnera pas. Il faut absolument que j'obtienne .22 à la fin. Ce qui est drôle c'est que dépendamment de la valeur qui est divisé des fois ça fonctionne et d'autres fois non.

  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 weis3r Voir le message
    Il faut absolument que j'obtienne .22 à la fin.
    Ca n'existe pas avec les réels en C. Il faut revoir ta conception.

  5. #5
    Membre éprouvé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    1 299
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 1 299
    Par défaut
    Une idée consisterait peut être à travailler avec des exposants. Au lieu de

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    var = 1111111111122
    tu mets

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    var = 1.111111111122e12
    et quand tu veux diviser par 100 (pow(10,2)) tu modifies la valeur de l'exposant.

  6. #6
    Membre Expert
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2008
    Messages
    1 515
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France

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

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 515
    Par défaut
    Citation Envoyé par salseropom Voir le message
    Une idée consisterait peut être à travailler avec des exposants. Au lieu de

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    var = 1111111111122
    tu mets

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    var = 1.111111111122e12
    et quand tu veux diviser par 100 (pow(10,2)) tu modifies la valeur de l'exposant.
    Ca change quoi ? Comment est-ce que tu "modifies la valeur de l'exposant" ?

Discussions similaires

  1. Réponses: 8
    Dernier message: 02/05/2006, 16h07
  2. Besoin d'une précision pour try/catch, svp
    Par hallek60 dans le forum C++
    Réponses: 9
    Dernier message: 05/01/2006, 21h15
  3. [C++ Builder 6] Timer de précision pour chronomètre
    Par doudoustephane dans le forum C++Builder
    Réponses: 9
    Dernier message: 27/09/2005, 10h45
  4. [VB.NET]Besoin de précision pour architecture 3-tiers
    Par Dnx dans le forum Windows Forms
    Réponses: 8
    Dernier message: 14/09/2005, 09h09
  5. Réponses: 19
    Dernier message: 15/03/2005, 09h05

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