C语言qsort 对于malloc分配的二维数组 cmp函数怎么写,求大神赐教!!

int*b,**a;a=(int**)malloc(500000*sizeof(int));for(i=0;i<500000;i++){b=malloc(2*sizeof... int *b,**a; a = (int**)malloc(500000*sizeof(int)); for(i=0;i<500000;i++) { b = malloc(2*sizeof(int)); a[i] = b; } 这样定义一个二维数组(500000*2) 我的qsort调用和cmp是这样写的 qsort(a,n,sizeof(a[0]),cmp); int cmp(const... int *b,**a; a = (int**)malloc(500000*sizeof(int)); for(i=0;i<500000;i++) { b = malloc(2*sizeof(int)); a[i] = b; } 这样定义一个二维数组(500000*2) 我的qsort调用和cmp是这样写的 qsort(a,n,sizeof(a[0]),cmp); int cmp(const void* a,const void* b) { if(*(int*)a != *(int*)b) return (*(int*)a - *(int*)b); else return *((int*)a+1)-*((int*)b+1); } 但是结果没有排序啊,急求大神赐教!指针这块都快要晕了 展开 展开
 我来答
江基牢珏
2019-02-05 · TA获得超过3895个赞
知道大有可为答主
回答量:3126
采纳率:34%
帮助的人:225万
展开全部
看起来你真的晕了。
先明确问题,你打算操作一个数组,数组的每个元素是一个指针,指向2个元素的数组。元素的大小关系为先比较第一个元素,第一个元素相同比较第二个元素。
如果这是样,你的分配代码就错了。
int
*b,**a;
a
=
(int**)malloc(500000*sizeof(int*));
//这里应是对int*来分配。
for(i=0;i<500000;i++)
{
b
=
malloc(2*sizeof(int));
a[i]
=
b;
}
qsort的调用是对。
cmp的写法有问题,入参实际是数组元素的指针,这里元素是int*,入参应该是int**,而你要比较的数组,这个指针指向的内容。
int
cmp(const
void*
a,const
void*
b)
{
int
*ap
=
*(int**)a;
int
*bp
=
*(int**)b;
if(ap[0]
==
bp[0])
return
ap[1]
-
bp[1];
else
return
a[0]
-
b[0];
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式