第1个回答 推荐于2017-09-24
1、在C语言中,一个数的有效数字取决于该数字所属的类型。
2、举例如下:
如果数12.3是int类型,那么12就是该数的有效数字,小数部分无效;
如果数12.3是float类型,那么12.3就是该数的有效数字。
如果数字超过其类型所能表示的范围,那么其就没有效数字。
第2个回答 2008-11-14
以下所述都指vc6.0环境,其他的可能有所不同。
单精度7位指的是整数部分加上小数部分的数字。比如
a=100000000.0/3.0;
printf("%10.20f\n",a);//输出33333334.00000000000000000...(20个0)
a=10.0/3.0;
printf("%10.20f\n",a);//3.3333332537....(小数部分共20位,但明显小数部分6位有效数字以后是错的)
.不算。
在printf的%f默认情况下(%和f间没有输出限制)是给小数部分输出6位数字,精度超出就输出错的,没超出就是精确值
第3个回答 2008-11-14
#include <iostream>
using namespace std;
int main(){
float ff=1.123456789101112f;
double dd=1.1234567891011121314151617;
cout<<ff<<endl;
cout<<dd<<endl;
return 0;
}
试一下啦!