为了表示浮点数,我们使用 floatdoublelong double

float和double有什么不同?

double 的精度比浮点数(float)高 2 倍。
float 是一个 32 位 IEEE 754 单精度浮点数,符号位为 1 位,(指数为 8 位,数值为 23),即 float 具有 7 个十进制数字的精度。
double 是 64 位 IEEE 754 双精度浮点数(符号 1 位,指数 11 位,值 52
位),即 double 具有 15 位十进制精度。

举个例子:
对于二次方程 x2 – 4.0000000 x + 3.9999999 = 0,10 位有效数字的精确根为 r1 = 2.000316228 和 r2 = 1.999683772

// C program to demonstrate
// double and float precision values

#include <stdio.h>
#include <math.h>

// utility function which calculate roots of
// quadratic equation using double values
void double_solve(double a, double b, double c){
    double d = b*b - 4.0*a*c;
    double sd = sqrt(d);
    double r1 = (-b + sd) / (2.0*a);
    double r2 = (-b - sd) / (2.0*a);
    printf("%.5ft%.5fn", r1, r2);
}

// utility function which calculate roots of
// quadratic equation using float values
void float_solve(float a, float b, float c){
    float d = b*b - 4.0f*a*c;
    float sd = sqrtf(d);
    float r1 = (-b + sd) / (2.0f*a);
    float r2 = (-b - sd) / (2.0f*a);
    printf("%.5ft%.5fn", r1, r2);
}

// driver program
int main(){
    float fa = 1.0f;
    float fb = -4.0000000f;
    float fc = 3.9999999f;
    double da = 1.0;
    double db = -4.0000000;
    double dc = 3.9999999;

    printf("roots of equation x2 - 4.0000000 x + 3.9999999 = 0 are : n");
    printf("for float values: n");
    float_solve(fa, fb, fc);

    printf("for double values: n");
    double_solve(da, db, dc);
    return 0;
}

运行结果如下:

roots of equation x2 - 4.0000000 x + 3.9999999 = 0 are : 
for float values: 
2.00000    2.00000
for double values: 
2.00032    1.99968
欢迎任何形式的转载,但请务必注明出处,尊重他人劳动成果。
转载请注明:文章转载自 有区别网 [http://www.vsdiffer.com]
本文标题:C/C++中float和double的区别
本文链接:https://www.vsdiffer.com/vs/difference-float-double-c-cpp.html
免责声明:以上内容仅是站长个人看法、理解、学习笔记、总结和研究收藏。不保证其正确性,因使用而带来的风险与本站无关!如本网站内容冒犯了您的权益,请联系站长,邮箱: ,我们核实并会尽快处理。