`
hellobin
  • 浏览: 62920 次
  • 性别: Icon_minigender_1
社区版块
存档分类
最新评论

qsort()应用大全

 
阅读更多
1.qsort函数:

原 型: void qsort(void *base, int nelem, int width, int (*fcmp)(const void *,const void *));

功 能: 使用快速排序例程进行排序

参 数:

1 待排序数组首地址

2 数组中待排序元素数量

3 各元素的占用空间大小

4 指向函数的指针,用于确定排序的顺序

说 明:qsort函数是ANSI C标准中提供的,其声明在stdlib.h文件中,是根据二分法写的,其时间复杂度为n*log(n)。

qsort要求提供的函数是需要自己定义的一个比较函数,比较函数使得qsort通用性更好。有了比较函数qsort可以实现对数组、字符串、结构体等结构进行升序或降序排序。
如int cmp(const void *a, const void *b)中有两个元素作为参数(参数的格式不能变的。)返回一个int值,如果比较函数返回大于0,qsort就认为a > b,返回小于0,qsort就认为a < b。qsort知道元素的大小了,就可以把大的放前面去。如果你的比较函数返回本来应该是1的(即a > b),而却返回-1(小于0的数),那么qsort认为a < b,就把b放在前面去,但实际上是a > b的,所以就造成了降序排序的差别了。简单来说,比较函数的作用就是给qsort指明元素的大小事怎么比较的。



七种qsort排序方法


一、对int类型数组排序
七种qsort排序方法



一、对int类型数组排序

 int num[100];

 Sample:

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


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




二、对char类型数组排序(同int类型)

 char word[100];


 Sample:


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


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





三、对double类型数组排序(特别要注意)

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);




四、对结构体一级排序


struct In
 {
 double data;
 int other;
 }s[100]





//按照data的值从小到大将结构体排序,关于结构体内的排序关键数据data的类型可以很多种,参考上面的例子写

int cmp( const void *a ,const void *b) 
{ 
return (*(In *)a)->data > (*(In *)b)->data ? 1 : -1; 
} 

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




五、对结构体二级排序

 struct In
 {
 int x;
 int y;
 }s[100];




//按照x从小到大排序,当x相等时按照y从大到小排序
int cmp( const void *a , const void *b ) 
{ 
struct In *c = (In *)a; 
struct In *d = (In *)b; 
if(c->x != d->x) return c->x - d->x; 
else return d->y - c->y; 
} 

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






六、对字符串进行排序

 struct In
 {
 int data;
 char str[100];
 }s[100];




//按照结构体中字符串str的字典顺序排序
int cmp ( const void *a , const void *b ) 
{ 
return strcmp( (*(In *)a)->str , (*(In *)b)->str ); 
} 

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





七、计算几何中求凸包的cmp

int cmp(const void *a,const void *b) //重点cmp函数,把除了1点外的所有点,旋转角度排序 
{ 
struct point *c=(point *)a; 
struct point *d=(point *)b; 
if( calc(*c,*d,p[1]) < 0) return 1; 
else if( !calc(*c,*d,p[1]) && dis(c->x,c->y,p[1].x,p[1].y) < dis(d->x,d->y,p[1].x,p[1].y)) //如果在一条直线上,则把远的放在前面 
return 1; 
else return -1; 
} 





PS:


其中的qsort函数包含在的头文件里,strcmp包含在的头文件里




3.sort和qsort比较:

1.cmp函数和qsort中cmp函数的不同

int cmp(const int &a,const int &b)

{

  return a>b

}

Sort中的cmp函数参数可以直接是参与比较的引用类型。

2.cmp函数比较时qsort用“-”,而sort用”>”.这也是一个重要的区别。



3.sort函数是c++中标准模板库的的函数,在qsort()上已经进行了优化,根据情况的不同可以采用不同的算法,所以较快。在同样的元素较多和同样的比较条件下,sort()的执行速度都比qsort()要快。另外,sort()是类属函数,可以用于比较任何容器,任何元素,任何条件。使用时需调用<algorithm>
sort(begin(),end(),cmp),
分享到:
评论

相关推荐

    qsort函数应用大全

    qsort函数应用大全

    qsort函数应用大全.doc

    某些人真的很贪,这么个小小的资源要10分。 我这里上传一个2003版本的doc文件且不要分,欢迎资源分较少的人下载。 另外调整了一些格式,方便阅读。

    qsort 与sort 的比较

    在c++中qsort()排序函数的使用qsort函数应用大全,在同样的元素和同样的比较条件下,sort()的执行速度都比qsort()要快。另外,sort()是类属函数,可以用于比较任何容器,任何元素,任何条件。

    吕鑫:【C++语法与数据结构第14天】【第1堂课】C语言函数qsort和bsearch功能

    1、讲解C语言标准函数qsort快速排序的功能和应用; 2、讲解C语言标准函数bsearch二分查找的功能和应用;

    VB指针葵花宝典之函数指针的配套代码。

    本代码主要是用来谈函数指针在VB内部的应用之一,给出了qsort和ShellSort的实现。其中ShellSort完全是取自1998年5月VBPJ的Black Belt专栏里的源代码,可以说本文的思想基本上也来自这篇专栏文章。 ShellSort提共...

    CListCtrl与CListBox应用实例

    下载吧! 绝对好的入门代码! VS08 写了几个小时 涉及内容: CListCtrl 与 CListBox 的基本操作,比如CListCtrl列移到CListBos,删除CListBox, 将CListCtrl导出至本地文件,再从本地文件导入至...对CListBox用qsort排序!

    C语言重点知识总结梳理

    14. C语言模拟实现qsort函数 练习: 15. C语言指针面试 16. C语言字符串与内存函数 C语言自定义类型: 17. C语言自定义类型-结构体 应用: 18. C语言实现通讯录 19. C语言自定义类型-枚举和联合 动态内存分配: 20. ...

    -C++参考大全(第四版) (2010 年度畅销榜

    参考大全第四版 本书是根据著名C语言专家HerbertSchildt的著作翻译的。这是一本关于C++语言的百科全书,包括C和C++的命令、功能、编程和应用等方面的内容。全书分为五个部分:C++基础:C子集;C++的专有特征;标准...

    二维数组排序

    应用c++库函数 qsort实现二维数组排序,即 举例:排序前:{{1,1,0} {3,0,2}, {1,1,1}, {1,2,0}} 排序后:{{1,1,0}, {1,1,1}, {1,2,0}, {3,0,2}}

    C语言解析教程(原书第4版)(美) 凯利.pdf

    8.5 例子:用qsort()进行排序 8.6 例子:带参数的宏 8.7 stdio.h和ctype.h中的宏 8.8 条件编译 8.9 预定义的宏 8.10 “#”和“##”操作符 8.11 assert()宏 8.12 使用#error和#pragma 8.13 行号 8.14 对应的函数 ...

    数据结构算法实现(严蔚敏版配套实现程序)

    ∷相关函数:QSort函数 1.5.9 一趟快速排序的改进算法 248 范例1-85 一趟快速排序的改进算法 248 ∷相关函数:QuickSort函数 1.5.10 简单选择排序 250 范例1-86 简单选择排序 250 ∷相关函数:SelectSort函数 1.5.11...

    数据结构 严蔚敏 代码

    ∷相关函数:QSort函数 1.5.9 一趟快速排序的改进算法 248 范例1-85 一趟快速排序的改进算法 248 ∷相关函数:QuickSort函数 1.5.10 简单选择排序 250 范例1-86 简单选择排序 250 ∷相关函数:SelectSort函数 1.5.11...

    数据结构(王)c元代码

    ∷相关函数:QSort函数 1.5.9 一趟快速排序的改进算法 248 范例1-85 一趟快速排序的改进算法 248 ∷相关函数:QuickSort函数 1.5.10 简单选择排序 250 范例1-86 简单选择排序 250 ∷相关函数:SelectSort函数 1.5.11...

    数据结构算法实现(严蔚敏版配套实现程序)

    ∷相关函数:QSort函数 1.5.9 一趟快速排序的改进算法 248 范例1-85 一趟快速排序的改进算法 248 ∷相关函数:QuickSort函数 1.5.10 简单选择排序 250 范例1-86 简单选择排序 250 ∷相关函数:SelectSort函数 1.5.11...

    DES数据加密

    qsort(aprandom, 256, sizeof(*aprandom), mysortproc); // final step - offsets for pointers are placed into output array for(i1=0; i1 ; i1++) { aresult[i1] = (int)(aprandom[i1] - arandom); } .....

    C语言通用范例开发金典.part2.rar

    ∷相关函数:QSort函数 1.5.9 一趟快速排序的改进算法 248 范例1-85 一趟快速排序的改进算法 248 ∷相关函数:QuickSort函数 1.5.10 简单选择排序 250 范例1-86 简单选择排序 250 ∷相关函数:SelectSort函数 ...

    C语言通用范例开发金典.part1.rar

    ∷相关函数:QSort函数 1.5.9 一趟快速排序的改进算法 248 范例1-85 一趟快速排序的改进算法 248 ∷相关函数:QuickSort函数 1.5.10 简单选择排序 250 范例1-86 简单选择排序 250 ∷相关函数:SelectSort函数 ...

    C 开发金典

    ∷相关函数:QSort函数 1.5.9 一趟快速排序的改进算法 248 范例1-85 一趟快速排序的改进算法 248 ∷相关函数:QuickSort函数 1.5.10 简单选择排序 250 范例1-86 简单选择排序 250 ∷相关函数:SelectSort函数 ...

    你必须知道的495个C语言问题

    基本的指针应用 4.1 指针到底有什么好处? 4.2 我想声明一个指针并为它分配一些空间,但却不行。这些代码有什么问题呢?char*p;*p=malloc(10); 4.3 *p++自增p还是p所指向的变量? 指针操作 4.4 我用指针...

    《你必须知道的495个C语言问题》

    基本的指针应用 45 4.1 指针到底有什么好处? 45 4.2 我想声明一个指针并为它分配一些空间,但却不行。这些代码有什么问题呢?char *p; *p =malloc(10); 45  4.3 *p++自增p还是p所指向的变量? 46 指针操作...

Global site tag (gtag.js) - Google Analytics