C++使用qsort函数

qsort是一个需要配合compare函数来使用的,用来排序的函数。

使用顺序为

qsort(待排序数组首地址,数组中待排序元素数量 ,各元素的占用空间大小 , 指向函数的指针);

例如

qsort(stu1,size1,sizeof(ELEMTYPE),cmp);

(stu1是数组,size是数量,cmp是个函数,compare函数)

compare函数定义时有很多需要注意的地方,例如

#include<stdio.h>
#include<stdlib.h>
#define MAXSIZE 100000

struct Student{
	int de,ca;
	long sdi;
}stu1[MAXSIZE],stu2[MAXSIZE],stu3[MAXSIZE],stu4[MAXSIZE];

typedef struct Student ELEMTYPE;

int cmp(const void *A,const void *B)
{
	ELEMTYPE *a=(ELEMTYPE *)A;
    ELEMTYPE *b=(ELEMTYPE *)B;
    int d1=a->de;
    int d2=b->de;
	int c1=a->ca;
	int c2=b->ca;
	int id1=a->sdi,id2=b->sdi;
	int to1=d1+c1,to2=d2+c2;
    if(to1!=to2)
	{
		return to2-to1;
	}
	else if(d1!=d2)
		return d2-d1;
	else return id1-id2;
}

它的cmp函数的形参必须强制转换成要求的格式才能进行使用,并且,从小到大A-B,反过来B-A。

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值