本文主要是介绍Tsukinai的第二十六个程序(记录数据并求排序输出原数据,平均值),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
Tsukinai的第二十六个程序
输入不超过20个非负整数(输入每个整数后按回车,以-1结束且不计入整数个数),用一维数组作函数参数编程实现如下功能:
(1)录入每个整数,函数原型:unsigned short ReadNumber(int num[]),num存储输入的整数,返回值为输入整数的个数;
(2)按由高到低的顺序排序,函数原型:void SortNumberDescending(int num[], unsigned short n),n为整数个数;
(3)对这些整数求和及平均值,函数原型:void SummingAveraging(int num[], unsigned short n, int *pSum, float *pAver),pSum指向和变量
,pAver指向平均值变量;
(4)输出这些整数,函数原型:void PrintNumber(int num[], unsigned short n) 。
主函数中按以下示例形式提示输入、调用函数(1)、调用函数(2)、提示输出、调用函数(4)、调用函数(3)、输出整数和及平均值。
Input Numbers:
87
Sort in descending order:
100
…
23
Sum=474,Aver=59.25
输入格式:
“Input Numbers:\n”
“%d”
输出格式:
“\nSort in descending order:\n”
“\nSum=%d,Aver=%.2f\n”
“%d\n”
#include<stdio.h>
int i;
unsigned short Readnumber(int num[])
{i = 0;unsigned short a = 0;do{scanf("%d", &num[i]);i++;a++;}while (num[i - 1] != -1);//一定要记得减1,在此之前i进行了加1操作return a - 1;
}
void SortNumberDescending(int num[], unsigned short n)
{int j, temp;for (i = n - 1; i > 0; i--){for (j = 0; j < n - 1; j++){if (num[j] < num[j + 1]){temp = num[j];num[j] = num[j + 1];num[j + 1] = temp;}}}
}
void SummingAveraging(int num[], unsigned short n, int *pSum, float *pAver)
{for (i = 0; i < n; i++){*pSum += num[i];}*pAver = (float) * pSum / n;
}
void PrintNumber(int num[], unsigned short n)
{for (i = 0; i < n; i++){printf("%d\n", num[i]);}
}
int main()
{int num[20], sum = 0;unsigned short x;float aver;printf("Input Numbers:\n");x = Readnumber(num);SortNumberDescending(num, x);SummingAveraging(num, x, &sum, &aver);printf("\nSort in descending order:\n");PrintNumber(num, x);printf("\nSum=%d,Aver=%.2f\n", sum, aver);return 0;
}
这篇关于Tsukinai的第二十六个程序(记录数据并求排序输出原数据,平均值)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!