|
网站首页
|
业界新闻
|
小组
|
威客
|
人才
|
下载频道
|
博客
|
代码贴
|
在线编程
|
编程论坛
|
登录
注册
短消息
我发表的主题
我参与的主题
我收藏的贴子
我上传的附件
我下过的附件
编辑个人资料
我的博客
用户控制面板
搜索
道具
恢复默认风格
碧海青天
秋意盎然
棕红预览
粉色回忆
蓝雅绿
紫色淡雅
青青河草
e点小镇
橘子红了
红红夜思
水晶紫色
雪花飘飘
新年快乐
风格
短消息
论坛展区
帮助
编程论坛
→
开发语言
→
C++论坛
→
『 C++教室 』
→ C++入学者想请教下一个简单的问题!麻烦大侠们帮下忙!
我的收件箱(0)
欢迎加入我们,一同切磋技术
用户名:
密 码:
共有
552
人关注过本帖
标题:
C++入学者想请教下一个简单的问题!麻烦大侠们帮下忙!
只看楼主
加入收藏
叱咤红人
等 级:
新手上路
帖 子:4
专家分:0
注 册:2015-10-23
结帖率:
100%
楼主
收藏
已结贴
√
问题点数:20 回复次数:4
C++入学者想请教下一个简单的问题!麻烦大侠们帮下忙!
图片附件: 游客没有浏览图片的权限,请
登录
或
注册
书上解释C++的float只保证6位有效位,但是有点疑惑,请教下!
上面的结果 hats+heats=61.419998 (正常计算应该是61.42)
hats-heats=39.080002 (正常计算应该是39.08)
hats*heats=561.292480 (正常计算应该是561.2925)
哪位能帮我解答下为什么吗!这6位有效位到底是什么意思?谢谢了!
2015-10-23 18:11
举报帖子
使用道具
赠送鲜花
wengbin
来 自:陕西西安
等 级:
贵宾
威 望:
19
帖 子:370
专家分:1846
注 册:2015-5-8
第
2
楼
收藏
得分:10
内存中存储的是你赋值的量的对应二进制数,读取和运算也是针对二进制数进行的,最后应该要进行浮点运算并显出来,经过浮点运算后,虽然算法是对的,但是用二进制数表示原来的数时可能会引起精度丢失,有人举例:0.45转换成二进制是个无限循环小数0.01110011100.。。。这样显示的结果也就和真正计算的不一样了
[此贴子已经被作者于2015-10-23 19:00编辑过]
2015-10-23 18:53
举报帖子
使用道具
赠送鲜花
叱咤红人
等 级:
新手上路
帖 子:4
专家分:0
注 册:2015-10-23
第
3
楼
收藏
得分:0
回复 2楼 wengbin
先谢过了,我看懂了,但这个6个有效位到底怎么算呢?就想知道什么时候该用float、什么时候用long呢?
2015-10-23 19:27
举报帖子
使用道具
赠送鲜花
wengbin
来 自:陕西西安
等 级:
贵宾
威 望:
19
帖 子:370
专家分:1846
注 册:2015-5-8
第
4
楼
收藏
得分:10
回复 3楼 叱咤红人
看你的需要呀,刚开始学习的时候float就够了吧,或者一般都定义double型的,双精度足够用了,精度的话,从小数点后数起就好了,比如39.080002,保证6位有效数字就是说080002都是准确的。呃,还有一点,long的问题,long和float不是能一起说的吧,float和double都是浮点表示的,用于定义可能是小数的量,而且double比float更精确。以前C中有long float型的定义,和double是一样的,现在已经不用这种表示法了
[此贴子已经被作者于2015-10-23 19:57编辑过]
2015-10-23 19:51
举报帖子
使用道具
赠送鲜花
叱咤红人
等 级:
新手上路
帖 子:4
专家分:0
注 册:2015-10-23
第
5
楼
收藏
得分:0
回复 4楼 wengbin
嗯,谢谢,懂了!是我搞混了,该问的是float与double!谢谢了!
2015-10-23 20:16
举报帖子
使用道具
赠送鲜花
5
1/1页
1
快速回复:
C++入学者想请教下一个简单的问题!麻烦大侠们帮下忙!
数据加载中...
关于我们
|
广告合作
|
编程中国
|
清除Cookies
|
TOP
|
手机版
编程中国
版权所有,并保留所有权利。
Powered by
Discuz
, Processed in 0.090236 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved