Bonjour,
J'ai écris mon double -13.99009 mais quand je l'affiche il est arrondi à 13.9901 quelqu'un a une solution?
On utilise CMake
Version imprimable
Bonjour,
J'ai écris mon double -13.99009 mais quand je l'affiche il est arrondi à 13.9901 quelqu'un a une solution?
On utilise CMake
Bonjour,
Il n'y a pas de solution simple en utilisant les types de base, c'est inhérent à la représentation des données dans nos ordinateurs.
Une solution que je trouve lourde pour un petit problème comme celui-là : installer l'application GMP, qui fait du calcul multi-précision, plus connue pour le calcul sur les entiers, mais qui calcule également avec des réels (si tu en as besoin, elle te fera des calculs sur plusieurs millions de décimales).
Sinon, tu peux transformer tes réels en entiers pas multiplication par un facteur suffisamment grand, mais ça atteint vite les limites.
:D
Merci,
je me disais aussi que c’était nos machines.
Je compte utilisait mpfr c'est la lib qui nous a été recommandé pour le projet, mais je voulais faire une implémentation par des doubles puis un peu plus tard quand on aura un truc fonctionnel utilisait mpfr.
Là, tu n'as pas un problème de précision de calcul, mais juste un, problème d'affichage :
Code:
1
2
3
4
5
6
7
8
9
10 #include <iostream> #include <iomanip> using namespace std; int main() { double d = -13.99009; cout << d << endl; cout << setprecision(10) << d << endl; }
Merci je pensais que ça venait du microprocesseur