对实型数据的舍入误差的疑问
在课中提供的程序如下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
这个是为什么呢???
本帖最后由 livcui 于 2020-7-31 11:23 编辑
不管怎么写,都有舍入误差啊? 不可能。 结果肯定是相同的
是真的输出的a和变成我后面写的那个样子了,我发不上去图片,大家不相信的话可以试试的。我用的软件是visualc++6.0 本帖最后由 会反光的小行星 于 2020-7-31 12:09 编辑
会反光的小行星 发表于 2020-7-31 11:52
是真的输出的a和变成我后面写的那个样子了,我发不上去图片,大家不相信的话可以试试的。我用的软件是visua ...
SHRS23 发表于 2020-7-31 11:49
结果肯定是相同的
我用的是void main(),你用的是int main().这儿可能是造成我们结果不一样的原因,我刚开始学,在这里没有权限发图片,不好意思啊。 会反光的小行星 发表于 2020-7-31 12:27
我用的是void main(),你用的是int main().这儿可能是造成我们结果不一样的原因,我刚开始学,在这里没有 ...
没有影响,我不截图了 本帖最后由 风过无痕1989 于 2020-7-31 13:58 编辑
我用的是VC++6.0,输出没有问题
https://xxx.ilovefishc.com/album/202007/31/135055zio5picqs373vc8u.jpg
PS:不对! b与 a 输出的结果是一样的,加 20 被忽略了 会反光的小行星 发表于 2020-7-31 12:27
我用的是void main(),你用的是int main().这儿可能是造成我们结果不一样的原因,我刚开始学,在这里没有 ...
用 int main() 与 void main() 的输出结果,我试过了是一样的,没有什么不同 SHRS23 发表于 2020-7-31 11:49
结果肯定是相同的
你的 20 也是因为太小了,被忽略了。。。 本帖最后由 风过无痕1989 于 2020-7-31 14:33 编辑
结论:1、与使用的编译器无关;
2、使用 int main() 与 使用 void main() 无关;
3、因输入的数值较大,将 float 型改为 double 型,数据才完美显示
https://xxx.ilovefishc.com/album/202007/31/140557cbfa0abba4gmxex7.jpg 风过无痕1989 发表于 2020-7-31 14:01
你的 20 也是因为太小了,被忽略了。。。
你仔细理解一下楼主的问题吧
这本来就是一段用来说明舍入误差的程序
+20是故意设定的
正常来说输出应该相同
楼主的问题在于
他的结果中分别输出ab
printf("%f\n",a);
printf("%f\n",b);
和一起输出ab
printf("%f,%f\n",a,b);
结果不同
SHRS23 发表于 2020-7-31 15:21
你仔细理解一下楼主的问题吧
这本来就是一段用来说明舍入误差的程序
+20是故意设定的
那是不可能的,我试了两个编译器,分开输出与同时输出结果是一样 风过无痕1989 发表于 2020-7-31 17:21
那是不可能的,我试了两个编译器,分开输出与同时输出结果是一样
是 因此,我们得出一个结论:
要么楼主描述问题错了,要么楼主在胡说。 截图,
发网络图片,上传到这:https://imgchr.com/,然后发图片 url 本帖最后由 会反光的小行星 于 2020-8-4 15:32 编辑
https://imgchr.com/i/a0c2Wj 会反光的小行星 发表于 2020-8-4 15:30
https://s1.ax1x.com/2020/08/04/a0c2Wj.jpg livcui 发表于 2020-8-1 14:34
截图,
发网络图片,上传到这:https://imgchr.com/,然后发图片 url
好的,谢谢,我发了截图了,大家可以看一下。其实我也是刚开始学习,具体什么原因我也不懂,不是瞎说的啊{:5_96:}
页:
[1]
2