`
hellobin
  • 浏览: 66280 次
  • 性别: 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 函数是 C 语言中一个标准的排序函数,用于对数组进行排序。它可以根据不同的比较函数来对不同的数据类型进行排序。本文将介绍 qsort 函数的七种应用方法,包括对整数、字符、浮点数、...

    C语言qsort排序大全 多种数据类型的qsort

    本篇将深入探讨`qsort`的使用,包括其基本原理、参数解析、不同数据类型的排序以及在实际编程中的应用技巧。 一、`qsort`函数的基本介绍 `qsort`函数原型如下: ```c void qsort(void *base, size_t nel, size_t ...

    qsort函数应用大全.doc

    qsort 函数应用大全 qsort 函数是 C 语言标准库中的一个函数,用于对数组进行排序。它是根据元素的值或结构体成员的值进行排序的。本文将对 qsort 函数的七种应用进行详细讲解。 一、对 int 类型数组排序 qsort ...

    qsort函数具体介绍

    qsort 函数详细介绍 qsort 函数是 C 语言标准库中的一种排序算法,用于对数组进行排序。它是快速排序(Quicksort)算法的...qsort 函数的应用非常广泛,我们可以根据实际情况选择合适的比较函数,实现 arrays 的排序。

    C语言qsort函数算法性能测试

    C语言qsort函数是一种高效的排序算法,广泛应用于各个领域。了解qsort函数的算法性能对程序设计和优化具有重要意义。本文将通过实验测试,深入探讨C语言qsort函数的算法性能,并对其进行详细分析。 qsort函数的时间...

    qsort的详细用法

    ### qsort函数详解与应用实例 #### 一、qsort函数概述 `qsort`是C语言中的标准库函数,用于对数组中的元素进行排序,它位于`&lt;stdlib.h&gt;`头文件中。此函数适用于各种数据类型,不仅限于基本类型如`int`或`double`,...

    分离出的微软qsort算法

    这样可以帮助你了解在实际应用中,微软的实现是否确实带来了性能提升。 总的来说,微软QSort是C语言快速排序的一种特定实现,可能包含多种优化技术,旨在提高在特定环境下的排序效率。通过深入研究源代码,我们可以...

    VC中qsort源代码

    通过本篇文章的学习,读者应能充分理解`qsort`函数的工作机制,了解其在实际项目中的应用场景,以及如何根据具体需求调整参数,以达到最优的排序效果。此外,掌握`qsort`的内部实现也有助于提升在算法设计和代码优化...

    qsort函数常见用法v1.1

    ### qsort函数详解及其在ACM竞赛中的应用 #### 一、qsort函数概述 `qsort`函数是C语言标准库中用于通用数组排序的一个强大工具,它使用快速排序算法,提供了高度灵活的排序机制。`qsort`的原型在`&lt;stdlib.h&gt;`...

    qsort 与sort 的比较

    相比之下,`std::sort()` 是C++ STL中的成员,它使用STL的迭代器接口,可以方便地应用于各种容器(如`vector`、`list`等)以及自定义类型。`sort()` 可以利用C++编译器的优化,通常执行速度更快。例如,对整型数组...

    qsort测试,闲人勿下

    `std::sort`则是在`&lt;algorithm&gt;`头文件中定义的,它是C++标准库的一部分,提供了更高级的功能,如稳定排序(即相等元素的相对顺序在排序后保持不变)和模板化,使得它可以应用于各种类型的容器,包括数组和向量。...

    七种qsort排序方法

    本文将详细介绍七种常见的`qsort`排序方法及其应用场景。 #### 二、基础知识 `qsort`函数的基本形式为: ```c void qsort(void *base, size_t num, size_t width, int (*compare)(const void *, const void *)); ``...

    C快速排序qsort

    快速排序的时间复杂度在平均情况下是O(n log n),最坏情况(数组已经排序或逆序)是O(n^2),但这种情况在实际应用中很少出现。快速排序通常比其他O(n log n)的排序算法如归并排序在实际运行上更快,因为它在原地排序...

    qsort使用法和具体举例说明

    qsort 是一种快速排序算法,广泛应用于 C 语言编程中。它可以对数组中的元素进行排序,包括整数、字符、浮点数、结构体等类型的元素。下面是 qsort 使用法和具体举例说明: 函数原型 void qsort(void *base, size_...

    qsort 各种用法

    ### qsort函数详解与应用实例 #### 引言 `qsort`是C语言标准库中的一个强大排序函数,它提供了灵活的通用性,能够处理各种数据类型和复杂度的数据结构排序需求。`qsort`函数的核心优势在于其比较函数参数,这允许...

    qsort测试,对一般人没用

    《深入解析qsort:超越日常应用的编程智慧》 在编程的世界里,排序算法是基础且重要的组成部分。本文将深入探讨C语言中的`qsort`函数,它是一个强大的通用排序工具,尽管对于日常简单编程任务可能显得有些复杂,但...

    C语言中qsort函数用法实例小结

    C语言中的`qsort`函数是用于对...在实际编程中,`qsort`函数是非常实用的工具,可以灵活地应用于各种场景下的数据排序,不仅限于上述示例。熟练掌握`qsort`函数的使用,能极大地提高C语言编程的效率和代码的可复用性。

    七种qsort排序

    标题:七种qsort排序 描述:本文详细介绍了七种使用C语言标准库函数`qsort()`进行排序的方法,适用于不同数据类型和复杂结构的...通过上述示例,读者应能充分理解并应用`qsort()`于实际问题中,提高程序的性能和功能。

    qsort快排函数源代码

    ### qsort快排函数源代码解析 #### 一、引言 `qsort`是C语言标准库中的一个强大而灵活的排序函数,用于对数组进行排序。它使用了快速排序算法作为其内部实现...这些技术对于理解和应用C语言中的排序算法具有重要意义。

    C库函数qsort七种使用方法示例

    C 库函数 qsort 七种使用方法示例 本文将对 C 库函数 qsort 进行详细的介绍,并提供七种使用方法示例,...通过本文的示例代码,可以帮助 C 语言初学者快速掌握 qsort 函数的使用方法,并且可以应用于实际的编程中。

Global site tag (gtag.js) - Google Analytics