14,325,048 members
Rate this:
See more:
In this program float x value is 1.234567890000 but output is 1.234567880630. I did't understand this output anybody explain

```#include<stdio.h>
#include<conio.h>

void main()
{
float x;
x = 1.234567890000;

printf("%.12lf\n",x);

getch();
}```
Posted
Amir Mahfoozi 4-Feb-12 0:59am

Change float to double and it produces what you wished :)

Rate this:

## Solution 1

Please do some reading on the limitations of floating point values. Here's a starter[^]

Right, a 5.
--SA
Rate this:

## Solution 2

File this away for future reference:

The "imprecision" is in producing the OUTPUT, the conversion of the binary / computer representation of the number into the string of characters that you display. This is true regardless of whether it is you printing the value or the debugger displaying it for you. Both processes need to take the binary value and convert it to a string of characters for your eyes.

If you a computing a value and wish to use it in other compututations then always carry the binary value around, don't convert it to a string and then reconvert it to binary. The binary value is as precise as you are going to get, converting it back and forth only adds "imprecision"

Computer binary representations (Base 2) and printed represetnations (in Base 10) are inherently incompatible and can only be approximated. You control the approximation with the format specifier for how many digits you want to see.

PS - when I was in college, I had a Comp Sci instructor who told us that "Floating Point Numbers have a precision of about 6 significant digits" (single precision back then). Concerning format statements, I asked "What happens when I ask it to print 10 digits after the decimal point? How does it get the extra 4 digits?" His response - "It makes them up." That's as true today as it was 45 years ago. You asked a single precision floating point number to print 12 digits of precision. It made some of them up :)
v2

Nice explanation, a 5.
--SA

Top Experts
Last 24hrsThis month
 OriginalGriff 80 Dave Kreskowiak 50 Richard MacCutchan 40 Richard Deeming 25 RickZeeland 20
 OriginalGriff 2,313 Maciej Los 1,330 phil.o 958 Richard Deeming 590 Richard MacCutchan 401

CodeProject, 503-250 Ferrand Drive Toronto Ontario, M3C 3G8 Canada +1 416-849-8900 x 100