double类型转换int类型时精度丢失

guoyabin2000 2006-11-03 02:00:25
问题如下:
double x, y;
DWORD a;
x = 4.0;
y = 0.01;
a = x / y;
执行完后a是399,我需要得到400。我需要怎样做?
各位大侠帮忙啊!很急,在线等
...全文
528 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
dfkoko 2006-11-03
  • 打赏
  • 举报
回复
double x, y;
double a;
x = 4.0;
y = 0.01;
a = x / y;

a=400
pcboyxhy 2006-11-03
  • 打赏
  • 举报
回复
二进制方式的浮点数表示不是精确的

很多数在计算机里面无法使用二进制浮点数计数法表示出来
比如5.1
OOPhaisky 2006-11-03
  • 打赏
  • 举报
回复
同意taodm(taodm) 的做法,跟浮点数打交道,要小心,还要学会忍耐^_^
femalelover 2006-11-03
  • 打赏
  • 举报
回复
标记
KenYuan2016 2006-11-03
  • 打赏
  • 举报
回复
四舍五入吧
a = x / y; 改为 a =( x / y + 0.5);
Macor 2006-11-03
  • 打赏
  • 举报
回复
用的是vc7???
看下环境变量你是怎么设的,或者直接开个console再试一把

我试了把
double x, y;
DWORD a;
x = 4.0;
y = 0.01;
a = x / y;
----------------
a = 400
weijiangshanwww 2006-11-03
  • 打赏
  • 举报
回复
比如说4/0.001
你可以先变成4/1=4

然后你移回来3位,就是4000了,

反正大概的思想了!
weijiangshanwww 2006-11-03
  • 打赏
  • 举报
回复
double x, y;
DWORD a;
x = 4.0;
y = 0.01;
a = x / y;
===========================

那你试着移位,然后计算,再移位回来。

asusa3a 2006-11-03
  • 打赏
  • 举报
回复
既然涉及到精度问题,怎么还这么做?为啥不另起方法?
guoyabin2000 2006-11-03
  • 打赏
  • 举报
回复
谢谢楼上的帮忙,还有没有其他的办法了?
C语言里有没有像Delphi里的Trunc和round的函数
taodm 2006-11-03
  • 打赏
  • 举报
回复
没办法确保!

a = x /y + 0.5;会让你好过点。

也许,你使用double本来就是个错误。
计算机只保证(小)整数运算是精确的。
hourui 2006-11-03
  • 打赏
  • 举报
回复
四舍五入吧
a = x / y; 改为 a =( x / y + 0.5);

64,651

社区成员

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

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