在c语言中,有效数字和有效数位怎么解释?

来源:百度知道 编辑:UC知道 时间:2024/06/21 03:30:32
单精度的有效数字是7位,比如1234.56789这个数,在输出时,结果是多少?
"."是不是有效数字?

以下所述都指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位数字,精度超出就输出错的,没超出就是精确值

有效数字位数是小数点以后的数字位数,而电脑输出的数字位数决定于定义变量的模式,并一般采用“四舍五入”的方法。

int i;

printf("Enter a value for i...\n");
scanf("%d", &i);

键盘输入0.333,储存到变量i里的数是0(约掉了)
如果改成:
double i;

那就会储存0.333000
在输出数值的时候可以先设定有效数值位数:
double i;

printf("Enter a value for i...\n");
scanf("%d", &i);

printf("\ni = %.4lf", i);
在输出的时候在电脑上会输出“i = 0.3330”

.在处理过程中不会当做有效数字位数来处理。

有效数字位数还可以通过常量来设定,在此不再赘述。
希望对你有用!

1、在C语言中,一个数的有效数字取决于该数字所属的类型。
2、举例如下:
如果数12.3是int类型,那么12就是该数