2017年12月12日 qsort函数理解、多态的实验

1.qsort函数

void qsort(void *base,size_t num,size_t width,int compare(const void * a,const void * b))

第一个参数填数组名

第二个填要排序的个数

第三个填每个参数的大小

第四个注意类型转换,a和b应该强制类型转换为指向数组元素类型的指针类型

如:数组为CShape * PShape[100];

qsort函数为qsort(PShape,n,sizeof(CShape*),MyCompare);

那么MyCompare怎么写呢:

int MyCompare(const void * a,const void * b)
{
CShape * a_ = (CShape*)a;
CShape * b_ = (CShape*)b;
if ((a_)->Area() > (b_)->Area())
return 1;
if ((a_)->Area() < (b_)->Area())
return -1;
if ((a_)->Area() == (b_)->Area())
return 0;

}//这样写就是错误的!!! 因为数组类型为CShape*,应该转换成指向
 CShape*类型

所以应该改成:

int MyCompare(const void * a,const void * b)
{
CShape ** a_ = (CShape**)a;
CShape ** b_ = (CShape**)b;
if ((*a_)->Area() > (*b_)->Area())
return 1;
if ((*a_)->Area() < (*b_)->Area())
return -1;
if ((*a_)->Area() == (*b_)->Area())
return 0;
}


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值