如何用c语言将数字从大到小排序
时间: 2024-12-06 11:26:59 浏览: 37
在C语言中,我们可以使用数组和标准库函数`qsort()`来对一组整数进行降序排序。这里是一个基本的例子:
```c
#include <stdio.h>
#include <stdlib.h> // 引入qsort库
// 定义比较函数,用于qsort()
int compare(const void* a, const void* b) {
return (*(int*)b - *(int*)a); // 如果第一个元素大于第二个,则返回正数,反之返回负数
}
void sort_descending(int arr[], int n) {
qsort(arr, n, sizeof(int), compare); // 对数组进行降序排列
}
int main() {
int numbers[] = {5, 9, 1, 7, 4, 6};
int size = sizeof(numbers) / sizeof(numbers[0]);
printf("Original array: ");
for (int i = 0; i < size; i++) {
printf("%d ", numbers[i]);
}
sort_descending(numbers, size);
printf("\nSorted in descending order: ");
for (int i = 0; i < size; i++) {
printf("%d ", numbers[i]);
}
return 0;
}
```
在这个例子中,我们首先声明了一个比较函数`compare()`,它接受两个指针作为参数,然后根据它们指向的数值大小决定返回值。`qsort()`函数会根据这个比较函数的返回值来调整数组元素的顺序。
在`main()`函数里,我们创建了一个整数数组并调用了`sort_descending()`函数对其进行排序。最后打印出排序前后的数组内容。
阅读全文