鱼C论坛

 找回密码
 立即注册
查看: 4490|回复: 26

对实型数据的舍入误差的疑问

[复制链接]
发表于 2020-7-31 11:12:18 | 显示全部楼层 |阅读模式

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

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

x
在课中提供的程序如下
void main()
{

float a,b;
a=123456.789e5;
b=a+20;
printf("%f\n",a);
printf("%f\n",b);
}
输出的结果是体现了实型数据的舍入误差的但是将输出修改成
printf("%f,%f\n",a,b);
以后就没有舍入误差了。
其中输出a=12345678848.000000   b=12345678868.000000
这个是为什么呢???
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-7-31 11:20:51 | 显示全部楼层
本帖最后由 livcui 于 2020-7-31 11:23 编辑

不管怎么写,都有舍入误差啊?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-7-31 11:36:46 | 显示全部楼层
不可能。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-7-31 11:49:20 | 显示全部楼层
结果肯定是相同的

2020-07-31_114829.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-7-31 11:52:52 | 显示全部楼层
是真的输出的a和变成我后面写的那个样子了,我发不上去图片,大家不相信的话可以试试的。我用的软件是visualc++6.0
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-7-31 12:03:23 | 显示全部楼层
本帖最后由 会反光的小行星 于 2020-7-31 12:09 编辑
会反光的小行星 发表于 2020-7-31 11:52
是真的输出的a和变成我后面写的那个样子了,我发不上去图片,大家不相信的话可以试试的。我用的软件是visua ...


想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-7-31 12:27:02 | 显示全部楼层
SHRS23 发表于 2020-7-31 11:49
结果肯定是相同的

我用的是void main(),你用的是int main().这儿可能是造成我们结果不一样的原因,我刚开始学,在这里没有权限发图片,不好意思啊。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-7-31 13:24:20 | 显示全部楼层
会反光的小行星 发表于 2020-7-31 12:27
我用的是void main(),你用的是int main().这儿可能是造成我们结果不一样的原因,我刚开始学,在这里没有 ...

没有影响,我不截图了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-7-31 13:51:25 | 显示全部楼层
本帖最后由 风过无痕1989 于 2020-7-31 13:58 编辑

我用的是VC++6.0,输出没有问题


                               
登录/注册后可看大图


PS:不对! b  与 a 输出的结果是一样的,加 20 被忽略了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-7-31 13:54:20 | 显示全部楼层
会反光的小行星 发表于 2020-7-31 12:27
我用的是void main(),你用的是int main().这儿可能是造成我们结果不一样的原因,我刚开始学,在这里没有 ...

用 int main() 与 void main() 的输出结果,我试过了是一样的,没有什么不同
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-7-31 14:01:20 | 显示全部楼层
SHRS23 发表于 2020-7-31 11:49
结果肯定是相同的

你的 20 也是因为太小了,被忽略了。。。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-7-31 14:07:17 | 显示全部楼层
本帖最后由 风过无痕1989 于 2020-7-31 14:33 编辑

结论:1、与使用的编译器无关;
          2、使用 int main() 与 使用 void main() 无关;
          3、因输入的数值较大,将 float 型改为 double 型,数据才完美显示


                               
登录/注册后可看大图
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-7-31 15:21:59 | 显示全部楼层
风过无痕1989 发表于 2020-7-31 14:01
你的 20 也是因为太小了,被忽略了。。。

你仔细理解一下楼主的问题吧
这本来就是一段用来说明舍入误差的程序
+20是故意设定的
正常来说输出应该相同


楼主的问题在于
他的结果中分别输出ab
printf("%f\n",a);
printf("%f\n",b);
和一起输出ab
printf("%f,%f\n",a,b);
结果不同
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-7-31 17:21:35 | 显示全部楼层
SHRS23 发表于 2020-7-31 15:21
你仔细理解一下楼主的问题吧
这本来就是一段用来说明舍入误差的程序
+20是故意设定的

那是不可能的,我试了两个编译器,分开输出与同时输出结果是一样
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-7-31 17:24:11 | 显示全部楼层
风过无痕1989 发表于 2020-7-31 17:21
那是不可能的,我试了两个编译器,分开输出与同时输出结果是一样

是                     
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-8-1 14:11:11 | 显示全部楼层
因此,我们得出一个结论:
要么楼主描述问题错了,要么楼主在胡说。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-8-1 14:34:10 | 显示全部楼层
截图,
发网络图片,上传到这:https://imgchr.com/,然后发图片 url
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-8-4 15:30:55 | 显示全部楼层
本帖最后由 会反光的小行星 于 2020-8-4 15:32 编辑


                               
登录/注册后可看大图
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-8-4 15:33:10 | 显示全部楼层


                               
登录/注册后可看大图
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-8-4 15:34:57 | 显示全部楼层
livcui 发表于 2020-8-1 14:34
截图,
发网络图片,上传到这:https://imgchr.com/,然后发图片 url

好的,谢谢,我发了截图了,大家可以看一下。其实我也是刚开始学习,具体什么原因我也不懂,不是瞎说的啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-12 23:13

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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