Printing the correct number of decimal points with cout
With <iomanip>
, you can use std::fixed
and std::setprecision
Here is an example
#include <iostream>
#include <iomanip>
int main()
{
double d = 122.345;
std::cout << std::fixed;
std::cout << std::setprecision(2);
std::cout << d;
}
And you will get output
122.34
How to 'cout' the correct number of decimal places of a double value?
Due to the fact the float
and double
are internally stored in binary, the literal 7.40200133400
actually stands for the number 7.40200133400000037653398976544849574565887451171875
...so how much precision do you really want? :-)
#include <iomanip>
int main()
{
double x = 7.40200133400;
std::cout << std::setprecision(51) << x << "\n";
}
And yes, this program really prints 7.40200133400000037653398976544849574565887451171875!
How do I print a double value with full precision using cout?
You can set the precision directly on std::cout
and use the std::fixed
format specifier.
double d = 3.14159265358979;
cout.precision(17);
cout << "Pi: " << fixed << d << endl;
You can #include <limits>
to get the maximum precision of a float or double.
#include <limits>
typedef std::numeric_limits< double > dbl;
double d = 3.14159265358979;
cout.precision(dbl::max_digits10);
cout << "Pi: " << d << endl;
c++ cout [double] not printing decimal places
This happens because of the distinction between the default notation and the fixed notation.
According to documentation,
- Using the default floating-point notation, the precision field specifies the maximum number of meaningful digits to display in total counting both those before and those after the decimal point. Notice that it is not a minimum, and therefore it does not pad the displayed number with trailing zeros if the number can be displayed with less digits than the precision.
- In both the fixed and scientific notations, the precision field specifies exactly how many digits to display after the decimal point, even if this includes trailing decimal zeros. The digits before the decimal point are not relevant for the precision in this case
(emphasis is added).
The stream uses the default floating-point notation until (or unless) you switch it to fixed or scientific notation. Since your number has six digit before the decimal point, and the default precision is also set to six, the floating-point numbers look like integers.
std::cout print all digits of float value
Assuming that the implementation uses radix 2 for the floating point,if (std::numeric_limits<T>::radix == 2)
then writing ALL the decimal digits for ALL possible values would require:
std::cout << std::setprecision(std::numeric_limits<T>::digits - std::numeric_limits<T>::min_exponent);
I suspect that the formulation would be the same for radix == 10, but I cannot check this (no implementation at hand).
I wonder why you want to print all the decimals. If it's just to reconstruct the value unchanged, this is not necessary. Using a mixture of scientific notation with a precision std::numeric_limits<T>::max_digits10
should do the job. Otherwise, there are well known algorithm to print just enough decimal digits. They are used in the main REPL languages (see python repr
, or how java, javascript, some Smalltalk, etc... print the floating point values), unfortunately, they are not part of a standard C++ library AFAIK.
How to output with 3 digits after the decimal point with C++ stream?
Use setf
and precision
.
#include <iostream>
using namespace std;
int main () {
double f = 3.14159;
cout.setf(ios::fixed,ios::floatfield);
cout.precision(3);
cout << f << endl;
return 0;
}
This prints 3.142
Related Topics
Setting Timeout for C/C++ Function Call
Regex Match Digits Between Strings
How to Read N Bytes from a File and Put Them into a Vector<Uint8_T> Using Iterators
C++ Reading CSV File and Assigning Values to Array
Correct Way of Passing Pointer to Another Thread
C++: How to Iterate Over Each Char in a String
How Come a Non-Const Reference Cannot Bind to a Temporary Object
Vector Converted All Negative Values to Zero
How to Install (V142) Build Tools in Visual Studio
Most Efficient Way of Copying a Raw Byte Array into an Empty Byte Vector
What Is External Linkage and Internal Linkage
Case-Insensitive String Comparison in C++
How to Print a Variable'S Type in Standard C++
Implicit Type Conversion Rules in C++ Operators
Overloading Friend Operator≪≪ For Template Class