曲径通幽论坛

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

qsort() -- 快速排序

[复制链接]

4917

主题

5879

帖子

3万

积分

GROAD

曲径通幽,安觅芳踪。

Rank: 6Rank: 6

积分
34382
跳转到指定楼层
楼主
发表于 2011-12-8 09:45:40 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
C++ 标准库里的 qsort() 函数是一个基于快速排序算法的排序函数,它可以对一个数组中的内容进行排序,它的原型包含在头文件 <cstdlib> 中,其原型如下:
[C++] 纯文本查看 复制代码
void qsort ( void * base, size_t num, size_t size, int ( * comparator ) ( const void *, const void * ) );

函数描述为:对由第一个参数 base 所指向的数组进行排序,第 3 个参数 size 表示该数组的元素的大小,第  2 个参数 num 表示数组的元素个数,第 4 个参数是个函数指针,指向一个自定义函数,该函数会被排序算法所使用。

comparator() 接受两个指针参数,且这两个指针的类型和欲排列数组中的元素类型一致。qsort() 的排序算法正是利用该函数来比较数组中的两个元素,所以在 comparator() 中,我们需要返回两个元素的比较结果:如果相等则返回 0 ,如果第 1 个参数大于第 2 个就返回正数,反之返回负数。


示例1:排序字符串
[C++] 纯文本查看 复制代码
#include "stdafx.h"
#include <cstdlib>
#include <iostream>
using namespace std;

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

int _tmain(int argc, _TCHAR* argv[])
{
    char str[] = "rqfvcdsaewzxtjnbhguyimlkpo";

    qsort(str, strlen(str), 1, comparator);
    cout << "sorted string: " << str << endl;

    return 0;
}

运行输出:
sorted string: abcdefghijklmnopqrstuvwxyz

示例2:排序整数
[C++] 纯文本查看 复制代码
#include "stdafx.h"
#include <cstdlib>
#include <iostream>
using namespace std;

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

int _tmain(int argc, _TCHAR* argv[])
{
    int num[] = {10, 30, 8, 4, 11, 100, 101};
    int i;

    qsort(num, 7, sizeof(int), comparator);
    
    for (i = 0; i < 7; i++)
        cout << num[i] << ' ';

    cout << endl;

    return 0;
}

运行输出:
4 8 10 11 30 100 101

由上可见,原来数组中的内容被排序后的内容所替代。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2024-5-18 03:07 , Processed in 0.076734 second(s), 24 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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