微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

C 中 qsort 的原型

如何解决C 中 qsort 的原型

我正在编写一个使用 stdlib.h 中的 qsort 的程序。我的代码正在运行,但我想知道为什么我不必在比较函数的原型中声明任何内容

我的比较函数原型是:

int comparePoints();

我的 qsort 调用是:

    qsort(holdarray,NumbersOfTeams,sizeof(struct hold),comparePoints);

我的比较函数是:

int comparePoints(void *a,void *b,void *c,void *d){
int team1P,team2P,team1G,team2G;
team1P = ((struct hold *)a)->points;
team1G = ((struct hold *)c)->goalscored;
team2P = ((struct hold *)b)->points;
team2G = ((struct hold *)d)->goalscored;

if (team1P>team2P){
    return -1;
}

if (team1P == team2P){
    if (team1G > team2G)
    {
        return -1;
    }else
    {
        return 1; 
    }
}
else{
    return 1;
}    

}

希望你们能指教我!

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。