Fortran Coder

查看: 1897|回复: 2
打印 上一主题 下一主题

[数值问题] 请问这后面为什么会出现这一串数字呢

[复制链接]

3

帖子

2

主题

0

精华

新人

F 币
25 元
贡献
13 点
跳转到指定楼层
楼主
发表于 2023-5-20 10:47:59 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式
[Fortran] 纯文本查看 复制代码
program ex0407
real *8::a,b
a=100000
b=0.1000000000000000
write(*,*),a,"+",b,"=",a+b
stop
end

0O$DV{U0_YAXBR7VT89[_QM.png (34.95 KB, 下载次数: 201)

0O$DV{U0_YAXBR7VT89[_QM.png
分享到:  微信微信
收藏收藏 点赞点赞 点踩点踩

2033

帖子

12

主题

5

精华

论坛跑堂

臭石头雪球

F 币
1641 元
贡献
709 点

美女勋章热心勋章星光勋章新人勋章贡献勋章管理勋章帅哥勋章爱心勋章规矩勋章元老勋章水王勋章

沙发
发表于 2023-5-20 11:28:21 | 只看该作者
老生常谈的问题了。
你需要了解2个问题。

第一,浮点数是有误差的。单精度大约7位有效数字,双精度大约15位有效数字。

第二,常量也有精度。所以 100000.0 是单精度(大部分编译器是这样规定的),而双精度的需要写成 100000.d0
a=100000.d
b=0.1d0

3

帖子

2

主题

0

精华

新人

F 币
25 元
贡献
13 点
板凳
 楼主| 发表于 2023-5-20 11:29:53 | 只看该作者
哦哦  谢谢!
您需要登录后才可以回帖 登录 | 极速注册

本版积分规则

捐赠本站|Archiver|关于我们 About Us|小黑屋|Fcode ( 京ICP备18005632-2号 )

GMT+8, 2024-12-23 22:50

Powered by Tencent X3.4

© 2013-2024 Tencent

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