| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 448 人关注过本帖
标题:为什么结果是这样的?
只看楼主 加入收藏
zhouzhengbo
Rank: 1
等 级:新手上路
帖 子:18
专家分:0
注 册:2007-5-1
收藏
 问题点数:0 回复次数:5 
为什么结果是这样的?

源程序:
#include <iostream>
using namespace std;

int main()
{
double a=3.3;
double b=1.1;
int c;
c=a/b;
cout<<c<<endl;
system("pause");
return 0;
}

上述程序输出为2,不知道是为什么.我又试了其他的,发现如果a=2.2,4.4,8.8,17.6...等1.1的2的次幂的倍数时
输出为2,4,8,16...但是其他的时,如3.3,5.5,6.6,7.7..时,输出为2,4,5,6...
不知道是不是和计算机内部的舍入误差有关.请教了~~~~谢谢!!

搜索更多相关主题的帖子: 结果 
2007-10-15 22:36
HJin
Rank: 6Rank: 6
等 级:贵宾
威 望:27
帖 子:401
专家分:0
注 册:2007-6-9
收藏
得分:0 

#include <iostream>
using namespace std;


/**
2.9999999999999996000
2
Press any key to continue . . .
*/

int main()
{
double a=3.3;
double b=1.1;
int c;

printf("%.19f\n", a/b);

c=a/b;
cout<<c<<endl;
system("pause");
return 0;
}


I am working on a system which has no Chinese input. Please don\'t blame me for typing English.
2007-10-16 00:31
zhouzhengbo
Rank: 1
等 级:新手上路
帖 子:18
专家分:0
注 册:2007-5-1
收藏
得分:0 

谢谢.可是怎么解释发现如果a=2.2,4.4,8.8,17.6...等1.1的2的次幂的倍数时
输出为2,4,8,16...?

2007-10-16 07:42
HJin
Rank: 6Rank: 6
等 级:贵宾
威 望:27
帖 子:401
专家分:0
注 册:2007-6-9
收藏
得分:0 
if you really want to know how things work inside a computer, you need to know how numbers are represented in the memory.

IEEE standard for floating-point numbers is a good starting point.

I think it is IEEE 754.

I am working on a system which has no Chinese input. Please don\'t blame me for typing English.
2007-10-16 08:14
duffebear
Rank: 1
等 级:新手上路
威 望:2
帖 子:172
专家分:0
注 册:2007-1-30
收藏
得分:0 
应该是浮点数的存储形式

死后定当长眠 生前何须久睡
2007-10-16 09:18
zhouzhengbo
Rank: 1
等 级:新手上路
帖 子:18
专家分:0
注 册:2007-5-1
收藏
得分:0 

谢谢各位!

2007-10-17 17:40
快速回复:为什么结果是这样的?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.021846 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved