登录|注册|帮助中心|联系我们

导航
首页 综合百科 生活常识 数码科技 明星名人 传统文化 互联网 健康 影视 美食 教育 旅游 汽车 职场 时尚 运动 游戏 家电 地理 房产 金融 节日 服饰 乐器 歌曲 动物 植物
当前位置:首页 > 综合百科

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

发布时间:2023年1月7日责任编辑:张小云标签:暂无标签

为了表示浮点数,我们使用floatdoublelong 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 valuesvoiddouble_solve(doublea, doubleb, doublec){    doubled = b*b - 4.0*a*c;    doublesd = sqrt(d);    doubler1 = (-b + sd) / (2.0*a);    doubler2 = (-b - sd) / (2.0*a);    printf("%.5ft%.5fn", r1, r2);}// utility function which calculate roots of // quadratic equation using float valuesvoidfloat_solve(floata, floatb, floatc){    floatd = b*b - 4.0f*a*c;    floatsd = sqrtf(d);    floatr1 = (-b + sd) / (2.0f*a);    floatr2 = (-b - sd) / (2.0f*a);    printf("%.5ft%.5fn", r1, r2);}   // driver programintmain(){    floatfa = 1.0f;    floatfb = -4.0000000f;    floatfc = 3.9999999f;    doubleda = 1.0;    doubledb = -4.0000000;    doubledc = 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);    return0;}

输出:

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

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

其它知识推荐

溜溜百科知识网——分享日常生活学习工作各类知识。 垃圾信息处理邮箱 tousu589@163.com
icp备案号 闽ICP备14012035号-2 互联网安全管理备案 不良信息举报平台 Copyright 2023 www.6za.net All Rights Reserved