鱼C论坛

 找回密码
 立即注册
查看: 1770|回复: 3

[已解决]在c++里用float和double计算时的精度到底是怎样的呀?

[复制链接]
发表于 2022-4-14 09:08:46 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
在做练习的时候,要求十个实数相乘。这是第一版的答案:
(输入是2.12 8.46一类的两位小数)
#include<iostream>

using namespace std;

int main()
{
        float a;
        float product=1.0;
       
        for(int i=0;i<10;i++)
        {
                cin>>a;
                product*=a;
         }
         cout<<product;
         
         return 0;
}
然后答案不对(整数位相同,小数部分不对),我就猜是精度不够。
(第二版)然后我把float product改成了double product
结果还是不对
(第三版)最后我把float a也改成了double类型,就对了
问题是:这三版的运算精度究竟有什么不同?
我觉得二三版应该是精度相同的吧
因为输入只输入两位小数呀,我乘积精确了不就可以了,挠头
最佳答案
2022-4-14 09:17:38
本帖最后由 andy大宝 于 2022-4-14 09:18 编辑


float            4字节        数字介于 ±3.4E-38 和 ±3.4E38 之间                有效数字: 7
double        8字节        数字介于 ±1.7E-308 和 ±1.7E308之间             有效数字:16

也就是说,float到了小数点后第七位就不对了
现在float已经几乎被淘汰掉了,建议用douuble
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-4-14 09:17:38 | 显示全部楼层    本楼为最佳答案   
本帖最后由 andy大宝 于 2022-4-14 09:18 编辑


float            4字节        数字介于 ±3.4E-38 和 ±3.4E38 之间                有效数字: 7
double        8字节        数字介于 ±1.7E-308 和 ±1.7E308之间             有效数字:16

也就是说,float到了小数点后第七位就不对了
现在float已经几乎被淘汰掉了,建议用douuble
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-4-14 10:29:21 From FishC Mobile | 显示全部楼层
float 也不是完全无用,一般在简单代码中,发挥其作用不大(因为有 double 在,精度比 float 高),但是如果说是大项目开发,代码几千行,所用的内存不是小儿科,float 就能发挥其作用了,因为 double 空间所需是 float 的两倍大。一般需要用到浮点类型的,小数点后超过 7 位数的基本影响也不大(除非牵涉高级数学精度,数据分析精度等要求,否则 7 位之后的数基本是废,谁会在意纳米般大小的数据呢?)

如上,一般我们都习惯用 int,实际上大部分代码只需用 short 便可,可能是一种习惯,所以常用 int 吧。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-4-14 13:57:31 | 显示全部楼层
感谢,问题已解决
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-17 22:42

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表