用C编写程序,要求用户输入n个数,并将这n个数从大到小排序
时间: 2023-08-31 20:35:23 浏览: 63
### 回答1:
可以使用冒泡排序或快速排序等算法来实现。以下是使用冒泡排序的示例代码:
#include <stdio.h>
void bubble_sort(int arr[], int n) {
int i, j, temp;
for (i = 0; i < n - 1; i++) {
for (j = 0; j < n - i - 1; j++) {
if (arr[j] < arr[j + 1]) {
temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
int main() {
int n, i;
printf("请输入要排序的数的个数:");
scanf("%d", &n);
int arr[n];
printf("请输入%d个数:", n);
for (i = 0; i < n; i++) {
scanf("%d", &arr[i]);
}
bubble_sort(arr, n);
printf("从大到小排序后的结果为:");
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
### 回答2:
你可以使用C语言编写一个程序来实现用户输入n个数,并将这n个数从大到小排序的需求。下面是一个示例程序:
```C
#include <stdio.h>
void bubbleSort(int arr[], int n) {
int i, j, temp;
for (i = 0; i < n-1; i++) {
for (j = 0; j < n-i-1; j++) {
if (arr[j] < arr[j+1]) {
temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
}
int main() {
int n, i;
printf("请输入要排序的数字个数:");
scanf("%d", &n);
int arr[n];
printf("请输入%d个数字:\n", n);
for (i = 0; i < n; i++) {
scanf("%d", &arr[i]);
}
bubbleSort(arr, n);
printf("按照从大到小的顺序排序:\n");
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
return 0;
}
```
上述程序首先定义了一个名为`bubbleSort`的排序函数,它使用了冒泡排序算法,通过不断交换相邻的元素,将较大的数往后移动。然后在`main`函数中,用户首先输入要排序的数字个数n,然后根据n的大小定义一个数组arr来保存这n个数字。接下来,用户输入n个数字存储到数组arr中,然后调用`bubbleSort`函数进行排序。最后按照从大到小的顺序输出排序结果。
注意,在使用此程序时,需要确保输入的数字个数n小于或等于数组arr的长度。
### 回答3:
要使用C编写程序实现这个功能,需要使用一种排序算法,例如冒泡排序、选择排序或快速排序。以下是使用冒泡排序算法来实现用户输入n个数并进行从大到小排序的示例代码:
```c
#include <stdio.h>
void bubbleSort(int arr[], int n) {
int i, j, temp;
for (i = 0; i < n - 1; i++) {
for (j = 0; j < n - i - 1; j++) {
if (arr[j] < arr[j + 1]) {
temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
}
int main() {
int n, i;
printf("请输入要排序的数字个数:");
scanf("%d", &n);
int arr[n];
printf("请输入%d个数:\n", n);
for (i = 0; i < n; i++) {
scanf("%d", &arr[i]);
}
bubbleSort(arr, n);
printf("从大到小排序后的结果为:\n");
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
return 0;
}
```
以上程序首先要求用户输入要排序的数字个数n,然后用户输入n个数字,接着使用冒泡排序算法将这n个数字从大到小进行排序,最后输出排序后的结果。