double and accuracy

后端 未结 3 1836
一生所求
一生所求 2021-01-17 03:23

Using long double I get 18/19 = 0.947368421052631578..., and 947368421052631578 is the repeating decimal. Using double I

相关标签:
3条回答
  • 2021-01-17 03:55

    A double which is usually implemented with IEEE 754 will be accurate to between 15 and 17 decimal digits. Anything past that can't be trusted, even if you can make the compiler display it.

    0 讨论(0)
  • 2021-01-17 03:59

    A double typically provides 16(±1) decimal digits. Your example shows this:

         4   8  12  16
         v   v   v   v
    0.947368421052631578 long double
    0.947368421052631526 double
    

    The answers agree to 16 digits. This is what should be expected. Also note that there's no guarantee in the C Standard that a long double has more precision than a double.

    0 讨论(0)
  • 2021-01-17 04:14

    You're trying to represent every decimal number with a finite amount of bits. Some things just aren't expressible exactly in floating point. Expecting exact answers with floats is your first problem. Take a look at What Every Computer Scientist Should Know About Floating-Point Arithmetic

    Here's a summary from some lecture notes:

    As mentioned earlier, computers cannot represent real numbers precisely since there are only a finite number of bits for storing a real number. Therefore, any number that has infinite number of digits such as 1/3, the square root of 2 and PI cannot be represented completely. Moreover, even a number of finite number of digits cannot be represented precisely because of the way of encoding real numbers.

    0 讨论(0)
提交回复
热议问题