题目:
编写一个函数,返回一个double数组中最大的和最小的数之间的差值,并在一个简单的程序中测试这个函数。
对于题目无感,很容易,只是有一点疑惑,因为答案写的时候是
代码如下 |
复制代码 |
printf("The gap between max and min is: %gn",gap( array, WIDTH));
|
感觉很神奇,%g是什么?在我的笔记-说明符中并没有记录,然后翻到书上的章节里,也没有详细介绍,只是把它归类为解释成浮点型。
结果输出:
2.6
9.2
The dif between max and min is : 6.6
没有多余的0,看着很舒服。
于是乎,理解了%g,很好的东西。
我写的完整版:
代码如下 |
复制代码 |
#include
#define WIDTH 6
float dif(double [], int num);
int main(void)
{
double array[] = {4.3, 5.3, 2.6, 9.2, 2.8, 3.6};
printf("The dif between max and min is : %g", dif(array, WIDTH));
return 0;
}
float dif(double array[], int num)
{
int i;
float max, min;
for (i = 0, max = *array, min = *array; i < num; i++) {
if (*(array + i) > max)
max = *(array + i);
if (*(array + i) < min)
min = *(array + i);
}
printf("%gn", min);
printf("%gn", max);
return max - min;
}
|