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

admin2016-12-06  30

问题 请编一个函数float fun(double h),该函数的功能是:使变量h中的值保留两位小数,并对第三位进行四舍五入(规定h中的值为正数)。
    例如,若h值为1234.567,则函数返回1234.570000;若h值为1234.564,则函数返回1234.560000。
    注意:部分源程序在文件PROG1.C中。
    请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。
    试题程序:
1   #include<stdio.h>
2   #include<conio.h>
3   #include<stdlib.h>
4   float fun(float h)
5  {
6
7   }
8   void main()
9   {
10    FILE*Wf;
11   float a;
12  system(’’CLS’’);
13  printf(’’Enter a:’’);
14    scanf(’’%f’’,&a);
15  printf(’’The origina1 data is:’’;
16   printf(’’%f\n\n’’,a);
17    printf(’’The result:%f\n’’,fun(a));
18   /*****************/
19  wf=fopen(’’out.dat’’,’’w’’);
20   fprintf(wf,’’%f’’,fun(8.32533));
21    fclose(wf);
22   /**********/
23   }

选项

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

解析 注意:本题要求对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://kaotiyun.com/show/OVDp777K
0

最新回复(0)