标题:我的机器是不是浮点运算有错误?
只看楼主
xurundong
Rank: 1
等 级:新手上路
帖 子:19
专家分:0
注 册:2006-4-10
 问题点数:0 回复次数:5 
我的机器是不是浮点运算有错误?
我在c++中的代码如下,大家看看我的机器是运算有错误还是我对代码的理解有错误?
int main()
{
float abc;
abc=10/3;
abc=abc*10000;
cout<<abc<<endl;
//我在上面的程序的输出结果中看到
//abc的输出值是3000,为什么呢?
//abc是单精度的float数,结果应该
//是3333才对啊?帮忙解释一下。
return 0;
}
搜索更多相关主题的帖子: abc 浮点运算 机器 float 单精度 
2006-04-10 18:49
gototheworld
Rank: 1
等 级:新手上路
帖 子:218
专家分:0
注 册:2006-3-24
得分:0 
#include <iostream>
using namespace std;
int main()
{
float abc;
abc=(float)10/3;
cout<<abc<<endl;
abc=abc*10000;

cout<<abc<<endl;
//我在上面的程序的输出结果中看到
//abc的输出值是3000,为什么呢?
//abc是单精度的float数,结果应该
//是3333才对啊?帮忙解释一下。
return 0;
}

路漫漫其修远兮 吾将上下而求索
2006-04-10 19:31
xurundong
Rank: 1
等 级:新手上路
帖 子:19
专家分:0
注 册:2006-4-10
得分:0 
以下是引用gototheworld在2006-4-10 19:31:00的发言:
#include <iostream>
using namespace std;
int main()
{
float abc;
abc=(float)10/3;
cout<<abc<<endl;
abc=abc*10000;

cout<<abc<<endl;
//我在上面的程序的输出结果中看到
//abc的输出值是3000,为什么呢?
//abc是单精度的float数,结果应该
//是3333才对啊?帮忙解释一下。
return 0;
}

谢谢你,我的问题是解决了,可是为什么在整形的运算之后还是整形呢?
还有没有类似的规定?

2006-04-10 19:41
gototheworld
Rank: 1
等 级:新手上路
帖 子:218
专家分:0
注 册:2006-3-24
得分:0 
以下是引用xurundong在2006-4-10 19:41:00的发言:

谢谢你,我的问题是解决了,可是为什么在整形的运算之后还是整形呢?
还有没有类似的规定?

3/10这两个整型相除得到3,再将3赋值给double型的abc; 整形的运算之后还是整形,这当然了


路漫漫其修远兮 吾将上下而求索
2006-04-10 19:50
gototheworld
Rank: 1
等 级:新手上路
帖 子:218
专家分:0
注 册:2006-3-24
得分:0 
以下是引用gototheworld在2006-4-10 19:50:00的发言:

3/10这两个整型相除得到3,再将3赋值给double型的abc;

所以你需要类型转换


路漫漫其修远兮 吾将上下而求索
2006-04-10 19:52
song4
Rank: 7Rank: 7Rank: 7
等 级:贵宾
威 望:38
帖 子:1533
专家分:4
注 册:2006-3-25
得分:0 
(int)10/(int)3
都是整形得数也是整形 所以=3
  因为=是双目运算符 所以系统自动把这个数转化成DOUBLE
位数小的转化大的没有警告

嵌入式 ARM 单片机 驱动 RT操作系统 J2ME LINUX  Symbian C C++ 数据结构 JAVA Oracle 设计模式 软件工程 JSP
2006-04-10 20:55



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-56583-1-1.html




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

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