int cmp(const int *a, const int *b)不明白

#include <math.h>
#include <stdio.h>
#include <stdlib.h>

int cmp(const int *a, const int *b)
{
return abs(*b) - abs(*a);
}

int main(void)
{
int n, i, x[101];

while (scanf("%d", &n), n)
{
for (i = 0 ; i < n ; i++)
scanf("%d", x + i);
qsort(x, n, sizeof(int), cmp);
for (i = 0 ; i < n ; i++)
printf("%d%c", x[i], (i != n - 1 ? ' ' : '\n'));
}

return 0;
}

qsort(x, n, sizeof(int), cmp);不了解qsort
主要还是int cmp(const int *a, const int *b)不明白,大神能确切给我讲一下吗?谢谢了

qsort快排的库函数,cmp()是快排函数中需要调用的比较函数,也就是次排序应如何排(如是从大大小还是从小到大),此函数可缺省,也可自己写,你给的cmp就是自己写的意思应该是按绝对值的升序排序
温馨提示:答案为网友推荐,仅供参考

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网