任意输入20个互不相等的整数,编写代码实现以下功能:1.求20个数的平均数并输出;2.将20个数中的奇数全部输出,没有奇数提示“无奇数”;3.将20个数由大到小排序并输出。
时间: 2024-10-17 12:06:34 浏览: 21
```c
#include <stdio.h>
int main() {
int arr[20];
float sum = 0;
// 输入20个互不相等的整数
printf("请输入20个互不相等的整数:\n");
for (int i = 0; i < 20; i++) {
scanf("%d", &arr[i]);
sum += arr[i];
}
// 求平均数并输出
float average = sum / 20.0;
printf("20个数的平均数为 %.2f\n", average);
// 找出并输出奇数(或提示无奇数)
int odd_count = 0;
for (int i = 0; i < 20; i++) {
if (arr[i] % 2 != 0) {
printf("%d ", arr[i]);
odd_count++;
}
}
if (odd_count == 0) {
printf("\n无奇数\n");
}
// 将20个数由大到小排序并输出
qsort(arr, 20, sizeof(int), compare_descending);
printf("\n20个数由大到小排序为:\n");
for (int i = 0; i < 20; i++) {
printf("%d ", arr[i]);
}
return 0;
}
// 降序比较函数
int compare_descending(const void *a, const void *b) {
return (*(int*)b - *(int*)a);
}
```
这段代码首先定义了一个数组`arr`用于存储20个整数,然后通过循环从用户那里获取输入并计算总和。接下来,计算平均值、遍历数组找出奇数,并用快速排序算法对数组进行降序排序。
请注意,为了使用`qsort`函数,你需要添加一个自定义的比较函数`compare_descending`,这个函数负责决定元素在排序过程中的顺序。这里我们采用的是降序排列,如果需要升序排列,只需将`*(int*)b - *(int*)a`改为`*(int*)a - *(int*)b`即可。
阅读全文