sort函数

C语言sort函数如何使用



最佳答案

C语言中没有预置的sort函数。如果在C语言中,遇到有调用sort函数,就是自定义的一个函数,功能一般用于排序。

一、可以编写自己的sort函数。

如下函数为将整型数组从小到大排序。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
void  sort( int  *a,  int  l) //a为数组地址,l为数组长度。
{
     int  i, j;
     int  v;
     //排序主体
     for (i = 0; i < l - 1; i ++)
         for (j = i+1; j < l; j ++)
         {
             if (a[i] > a[j]) //如前面的比后面的大,则交换。
             {
                 v = a[i];
                 a[i] = a[j];
                 a[j] = v;
             }
         }
}

对于这样的自定义sort函数,可以按照定义的规范来调用。

二、C语言有自有的qsort函数。

功 能: 使用快速排序例程进行排序

头文件:stdlib.h

原型: void qsort(void *base,int nelem,int width,int (*fcmp)(const void *,const void *));

参数:

1 待排序数组首地址

2 数组中待排序元素数量

3 各元素的占用空间大小

4 指向函数的指针,用于确定排序的顺序

这个函数必须要自己写比较函数,即使要排序的元素是int,float一类的C语言基础类型。

以下是qsort的一个例子:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include<stdio.h>
#include<stdlib.h>
int  comp( const  void *a, const  void *b) //用来做比较的函数。
{
     return  *( int *)a-*( int *)b;
}
int  main()
{
     int  a[10] = {2,4,1,5,5,3,7,4,1,5}; //乱序的数组。
     int  i;
     qsort (a,n, sizeof ( int ),comp); //调用qsort排序
     for (i=0;i<10;i++) //输出排序后的数组
     {
         printf ( "%d\t" ,array[i]);
     }
     return  0;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值