曲径通幽论坛

 找回密码
 立即注册
搜索
查看: 4471|回复: 0
打印 上一主题 下一主题

[常规] qsort() -- 快速排序法排列数组

[复制链接]

4918

主题

5880

帖子

3万

积分

GROAD

曲径通幽,安觅芳踪。

Rank: 6Rank: 6

积分
34397
跳转到指定楼层
楼主
发表于 2012-1-7 14:33:13 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
qsort() 函数原型如下:
[C++] 纯文本查看 复制代码
#include <stdlib.h>
void qsort(void *base, size_t nmemb, size_t size, int(*compar)(const void *, const void *));

其中,base 指向欲排序的数组开始位置,nmemb 表示数组中的元素个数,每一个个元素的大小由 size 来表示。compar 是一个函数指针,该函数用来判断两个元素间的大小关系。qsort() 的排序算法正是利用该函数来比较数组中的两个元素,所以在 compa() 中,我们需要返回两个元素的比较结果:如果相等则返回 0 ,如果第 1 个参数大于第 2 个就返回正数,反之返回负数。

测试代码:
[C++] 纯文本查看 复制代码
#include <stdio.h>
#include <stdlib.h>


int compar(const void *a, const void *b)
{
    return *(int *)a - *(int *)b;
}

int main()
{
    int myarray[10] = {3, 8, 13, 83, 34, 58, 19, 65, 21, 64};

    int i;

    for (i = 0; i < 10; i++)
        printf ("%d ", myarray[i]);
    printf ("\n");

    qsort(myarray, 10, sizeof(int), compar);

    for (i = 0; i < 10; i++)
        printf ("%d ", myarray[i]);

    printf ("\n");

    return 0;
}

运行输出:
./qsort
3 8 13 83 34 58 19 65 21 64
3 8 13 19 21 34 58 64 65 83
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|曲径通幽 ( 琼ICP备11001422号-1|公安备案:46900502000207 )

GMT+8, 2025-6-18 03:00 , Processed in 0.086568 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表