c语言中sort函数怎么使用

avatar
作者
筋斗云
阅读量:0

在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 <stdio.h> #include <stdlib.h>  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进行升序排序,并输出排序后的结果。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!