会反光的小行星 发表于 2020-7-31 11:12:18

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

在课中提供的程序如下
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:20:51

本帖最后由 livcui 于 2020-7-31 11:23 编辑

不管怎么写,都有舍入误差啊?

永恒的蓝色梦想 发表于 2020-7-31 11:36:46

不可能。

SHRS23 发表于 2020-7-31 11:49:20

结果肯定是相同的

会反光的小行星 发表于 2020-7-31 11:52:52

是真的输出的a和变成我后面写的那个样子了,我发不上去图片,大家不相信的话可以试试的。我用的软件是visualc++6.0

会反光的小行星 发表于 2020-7-31 12:03:23

本帖最后由 会反光的小行星 于 2020-7-31 12:09 编辑

会反光的小行星 发表于 2020-7-31 11:52
是真的输出的a和变成我后面写的那个样子了,我发不上去图片,大家不相信的话可以试试的。我用的软件是visua ...

会反光的小行星 发表于 2020-7-31 12:27:02

SHRS23 发表于 2020-7-31 11:49
结果肯定是相同的

我用的是void main(),你用的是int main().这儿可能是造成我们结果不一样的原因,我刚开始学,在这里没有权限发图片,不好意思啊。

SHRS23 发表于 2020-7-31 13:24:20

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

没有影响,我不截图了

风过无痕1989 发表于 2020-7-31 13:51:25

本帖最后由 风过无痕1989 于 2020-7-31 13:58 编辑

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

https://xxx.ilovefishc.com/album/202007/31/135055zio5picqs373vc8u.jpg

PS:不对! b与 a 输出的结果是一样的,加 20 被忽略了

风过无痕1989 发表于 2020-7-31 13:54:20

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

用 int main() 与 void main() 的输出结果,我试过了是一样的,没有什么不同

风过无痕1989 发表于 2020-7-31 14:01:20

SHRS23 发表于 2020-7-31 11:49
结果肯定是相同的

你的 20 也是因为太小了,被忽略了。。。

风过无痕1989 发表于 2020-7-31 14:07:17

本帖最后由 风过无痕1989 于 2020-7-31 14:33 编辑

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

https://xxx.ilovefishc.com/album/202007/31/140557cbfa0abba4gmxex7.jpg

SHRS23 发表于 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);
结果不同

风过无痕1989 发表于 2020-7-31 17:21:35

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


那是不可能的,我试了两个编译器,分开输出与同时输出结果是一样

SHRS23 发表于 2020-7-31 17:24:11

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

是                     

永恒的蓝色梦想 发表于 2020-8-1 14:11:11

因此,我们得出一个结论:
要么楼主描述问题错了,要么楼主在胡说。

livcui 发表于 2020-8-1 14:34:10

截图,
发网络图片,上传到这:https://imgchr.com/,然后发图片 url

会反光的小行星 发表于 2020-8-4 15:30:55

本帖最后由 会反光的小行星 于 2020-8-4 15:32 编辑

https://imgchr.com/i/a0c2Wj

会反光的小行星 发表于 2020-8-4 15:33:10

会反光的小行星 发表于 2020-8-4 15:30


https://s1.ax1x.com/2020/08/04/a0c2Wj.jpg

会反光的小行星 发表于 2020-8-4 15:34:57

livcui 发表于 2020-8-1 14:34
截图,
发网络图片,上传到这:https://imgchr.com/,然后发图片 url

好的,谢谢,我发了截图了,大家可以看一下。其实我也是刚开始学习,具体什么原因我也不懂,不是瞎说的啊{:5_96:}
页: [1] 2
查看完整版本: 对实型数据的舍入误差的疑问