浮动多少位小数_浮动有效数字七位详解

Դ新浪

ߣ整站优化

20

2021-11-07 11:10:26

为了表示浮点数,我们使用floatdoublelong double有什么不同 ?

float多少位小数(float有效数字七位详解)

double的精度是float的2

float是32位IEEE 754单精度浮点数一位符号,(8位为指数,23 *为值),即漂浮物具有七位十进制数字精度。

double是64位的IEEE 754双精度浮点数(符号一位,指数11位,值52 *位),即两倍具有15位十进制数字的精度。

float多少位小数(float有效数字七位详解)

让我们举个例子:

对于二次方程x2 4.0000000 x + 3.9999999 = 0,精确到10个有效数字的根是r1=2.000316228和r2=1.999683772

//C程序演示

//双精度和浮点精度值

#包含stdio.h

#包括数学h .

//计算根的效用函数

//使用双精度值的二次方程

voiddouble_solve(doublea,doubleb,double c){ 0

翻倍=B * B- 4.0 * a * c;

double SD=sqrt(d);

双R1=(-b SD)/(2.0 * a);

双R2=(-B- SD)/(2.0 * a);

printf(' %。5英尺。5fn’,r1,R2);

}

//计算根的效用函数

//使用浮点值的二次方程

void float _ solve(float,floatb,float c){ 0

浮动d=B * B- 4.0 f * a * c;

float SD=sqrtf(d);

浮动R1=(-b标清)/(2.0f * a);

浮子R2=(-B- SD)/(2.0f * a);

printf(' %。5英尺。5fn’,r1,R2);

}

//驱动程序

int main(){ 0

floatfa=1.0f

浮子FB=-4.0000000 f;

floatfc=3.9999999f

doubleda=1.0

双db=-4.0000000;

doubledc=3.9999999

printf('公式x2 - 4.0000000 x 3.9999999=0的根为:n’);

printf('对于浮点值:n’);

float_solve(fa,fb,fc);

printf('对于双精度值:n’);

double_solve(da、db、DC);

返回0;

}

输出:

方程x24.0000000 x 3.9999999=0的根为:

对于浮点值: 2.00000 2.00000

对于双精度值: 2.00032 1.99968

通过以上实例,你掌握了这两个数据类型的不同之处了吗?希望对你有帮助哦~

佭ϴý Ѷ Media8ý

在线客服

外链咨询

扫码加我微信

微信:xmbfjc

返回顶部