qsort函数的笔记

头文件<stdlib.h>

void qsort(void*, size_t  , size_t, int ( * )(const void * ,  const void *  ))

如:qsort(tem, N, sizeof(int), cmp);

参数1:void *待排序的数据的首地址

参数2:数据的成员数

参数3:数据每个成员的长度

参数 4:比较函数

int ( * )(const void * ,  const void *  )

返回值是正的就交换,负数就不交换,0可能交换也可能不交换

如下,a>b则返回一个正数,执行交换,用该比较函数得出来的是升序排列 

int inc (const void * a,const void *b)//写的比较函数的两个传参在比较函数内的声明

必须是const void*型,使用的时候再强转为自己需要的类型

{

return *(int *)a - *(int *)b;//先把地址a和b强转为int*型地址后再解地址

}

将a和b的位置交换一下就可以得到降序排序的比较方法

用之前一定要将  a和b强转为你需要的数据类型

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值