C++ float类型 6.0f / 10.0f = 0.60000002 的问题

菜亲虫 2009-03-12 04:13:20

float a = 6.0f;
float b = 10.0f;
float c = a/b;//这时c 等于0.60000002 而不是0.6。


5.0f/10.0f就是正确的.
请问有谁知道如何避免以上问题吗?
...全文
323 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
精度问题,这么较真?
cuixd2020 2009-03-12
  • 打赏
  • 举报
回复
std::setprecision
sagegz 2009-03-12
  • 打赏
  • 举报
回复

#include <stdio.h>

int main(){
float a = 6.0f;
float b = 10.0f;
float c = a/b;
printf("%g",c);
}
vrace 2009-03-12
  • 打赏
  • 举报
回复
精度問題,是這樣的。。判斷的時候
if (fabs(c - 0.6f) <= 0.0000001) 就行了。。

64,670

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧