sort和qsort

来源:互联网 发布:淘宝商品上架时间查询 编辑:程序博客网 时间:2024/05/22 11:30

写哈夫曼编码,c++ ,需要找出节点里freq属性最小的两个节点进行合并。直接写了两个循环,看起来太傻了。都不知道用sort函数。

sort和qsort都是针对连续内存才能用,qsort是快速排序。加上#include <algorithm>

void qsort( void *base, size_t num, size_t width, int (__cdecl *compare ):

第一个参数 base 是 需要排序的目标数组名(或者也可以理解成开始排序的地址,因为可以写&s[i]这样的表达式)

第二个参数 num 是 参与排序的目标数组元素个数

第三个参数 width 是单个元素的大小(或者目标数组中每一个元素长度),推荐使用sizeof(s[0])这样的表达式

第四个参数 compare 就是让很多人觉得非常困惑的比较函数啦。int compare (const void *elem1, const void *elem2 ) );

例子:

double in[100];

int cmp( const void *a , const void *b )

{

return *(double *)a > *(double *)b ? 1 : -1;

}

qsort(in,100,sizeof(in[0]),cmp);

/***************************************************/

sort 是qsort升级版,

Sort(start,end,排序方法)

typedef struct s{...}t;

t test[100];

bool Compare(const t &a, const t &b)

{    return...  }

sort(test, test+100, Compare);

原创粉丝点击