请编—个函数float fun( double h), 该函数的功能是:使变量h中的值保留两位小数,并对第三位进行四舍五入(规定h中的值为正数)。 例如,若h值为1234, 567,则函数返回1234. 570000;若h值为1234.564,则函

admin2017-09-23  49

问题 请编—个函数float fun( double h),
该函数的功能是:使变量h中的值保留两位小数,并对第三位进行四舍五入(规定h中的值为正数)。
    例如,若h值为1234, 567,则函数返回1234. 570000;若h值为1234.564,则函数返回1234. 560000。
    注意:部分源程序在文件PROG1.C中。
    请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。
  试题程序:
#include  < stdio.h >
#include  < coni < *h >
#include  < stdlib.h >
float fun (float h )
{
}
void main ()
{
FILE *wf;
  float a;
   system ("CLS") ;
  printf ("Enter a: ") ;
  scanf ("% f"f &a) ;
   printf "The original data is  :  ") ;
  printf ("% f\n\n", a) :
  printf ("The result:%f\n", fun
(a));
/*********found*********/
wf = fopen "out.dat", "w") :
fprintf (wf, "f%  f", fun (8.32533));
fclose (wf) ;
/*********found*********/
}

选项

答案float fun (float h) { int tmp= (int) (h*1000+5) 110; /*单精度数h乘以1000后再加5,相当于对h中的第三位小数进行四舍五入,除以10后将其赋给一个长整型数时就把第三位小数后的数全部截去*/ return (float) tmp/100.0; /*除以100,保留2位小数*/ }

解析 注意:本题要求对h的值真正进行四舍五入运算,而不是为了输出,即不能用printf("%7.2f",h)来直接得到结果。四舍五入算法:如果要求精确到小数点后面的第n位,则需要对第n+1位进行运算。方法是将该小数乘以10的n+1次方后加5,然后除以10并强制转换变量类型为整型,再将该数除以10的n次方,同时强制转换类型为浮点型。
代码实现如下:
int t;/*定义整型变量t*/
t= (int)(h*10n+1+5)/10;/*对h进行操作,得到值浮点型,t取值时取整数部分。10n+1为要扩大的倍数*/
h=( float) t/10n
/*将t缩小10n倍,并转换成浮点型*/
转载请注明原文地址:https://jikaoti.com/ti/Kea0FFFM
0

最新回复(0)