在C语言中,sort函数用于对数组进行排序。其函数原型为:
void qsort(void *base, size_t nitems, size_t size, int (*compar)(const void *, const void *));
参数说明:
base
:指向要排序的数组的起始位置的指针。nitems
:数组中元素的个数。size
:数组中每个元素的大小(以字节为单位)。compar
:指向一个比较函数的指针,用于定义数组元素的排序规则。
比较函数的原型为:
int compar(const void *a, const void *b);
比较函数应该返回一个负数、零或正数,分别表示第一个参数应该排在第二个参数之前、相等或之后。比较函数的实现根据排序的需求而定。
下面是一个使用qsort
函数对整型数组进行升序排序的示例代码:
#include#include int compare(const void *a, const void *b) { return (*(int*)a - *(int*)b); } int main() { int arr[] = {5, 2, 8, 1, 6}; int n = sizeof(arr) / sizeof(arr[0]); qsort(arr, n, sizeof(int), compare); printf("Sorted array: "); for (int i = 0; i < n; i++) { printf("%d ", arr[i]); } return 0; }
以上代码会对数组arr
进行升序排序,并输出排序后的结果。