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 函数是 C 语言中一个标准的排序函数,用于对数组进行排序。它可以根据不同的比较函数来对不同的数据类型进行排序。本文将介绍 qsort 函数的七种应用方法,包括对整数、字符、浮点数、...
本篇将深入探讨`qsort`的使用,包括其基本原理、参数解析、不同数据类型的排序以及在实际编程中的应用技巧。 一、`qsort`函数的基本介绍 `qsort`函数原型如下: ```c void qsort(void *base, size_t nel, size_t ...
qsort 函数应用大全 qsort 函数是 C 语言标准库中的一个函数,用于对数组进行排序。它是根据元素的值或结构体成员的值进行排序的。本文将对 qsort 函数的七种应用进行详细讲解。 一、对 int 类型数组排序 qsort ...
qsort 函数详细介绍 qsort 函数是 C 语言标准库中的一种排序算法,用于对数组进行排序。它是快速排序(Quicksort)算法的...qsort 函数的应用非常广泛,我们可以根据实际情况选择合适的比较函数,实现 arrays 的排序。
C语言qsort函数是一种高效的排序算法,广泛应用于各个领域。了解qsort函数的算法性能对程序设计和优化具有重要意义。本文将通过实验测试,深入探讨C语言qsort函数的算法性能,并对其进行详细分析。 qsort函数的时间...
### qsort函数详解与应用实例 #### 一、qsort函数概述 `qsort`是C语言中的标准库函数,用于对数组中的元素进行排序,它位于`<stdlib.h>`头文件中。此函数适用于各种数据类型,不仅限于基本类型如`int`或`double`,...
这样可以帮助你了解在实际应用中,微软的实现是否确实带来了性能提升。 总的来说,微软QSort是C语言快速排序的一种特定实现,可能包含多种优化技术,旨在提高在特定环境下的排序效率。通过深入研究源代码,我们可以...
通过本篇文章的学习,读者应能充分理解`qsort`函数的工作机制,了解其在实际项目中的应用场景,以及如何根据具体需求调整参数,以达到最优的排序效果。此外,掌握`qsort`的内部实现也有助于提升在算法设计和代码优化...
### qsort函数详解及其在ACM竞赛中的应用 #### 一、qsort函数概述 `qsort`函数是C语言标准库中用于通用数组排序的一个强大工具,它使用快速排序算法,提供了高度灵活的排序机制。`qsort`的原型在`<stdlib.h>`...
相比之下,`std::sort()` 是C++ STL中的成员,它使用STL的迭代器接口,可以方便地应用于各种容器(如`vector`、`list`等)以及自定义类型。`sort()` 可以利用C++编译器的优化,通常执行速度更快。例如,对整型数组...
`std::sort`则是在`<algorithm>`头文件中定义的,它是C++标准库的一部分,提供了更高级的功能,如稳定排序(即相等元素的相对顺序在排序后保持不变)和模板化,使得它可以应用于各种类型的容器,包括数组和向量。...
本文将详细介绍七种常见的`qsort`排序方法及其应用场景。 #### 二、基础知识 `qsort`函数的基本形式为: ```c void qsort(void *base, size_t num, size_t width, int (*compare)(const void *, const void *)); ``...
快速排序的时间复杂度在平均情况下是O(n log n),最坏情况(数组已经排序或逆序)是O(n^2),但这种情况在实际应用中很少出现。快速排序通常比其他O(n log n)的排序算法如归并排序在实际运行上更快,因为它在原地排序...
qsort 是一种快速排序算法,广泛应用于 C 语言编程中。它可以对数组中的元素进行排序,包括整数、字符、浮点数、结构体等类型的元素。下面是 qsort 使用法和具体举例说明: 函数原型 void qsort(void *base, size_...
《深入解析qsort:超越日常应用的编程智慧》 在编程的世界里,排序算法是基础且重要的组成部分。本文将深入探讨C语言中的`qsort`函数,它是一个强大的通用排序工具,尽管对于日常简单编程任务可能显得有些复杂,但...
C语言中的`qsort`函数是用于对...在实际编程中,`qsort`函数是非常实用的工具,可以灵活地应用于各种场景下的数据排序,不仅限于上述示例。熟练掌握`qsort`函数的使用,能极大地提高C语言编程的效率和代码的可复用性。
标题:七种qsort排序 描述:本文详细介绍了七种使用C语言标准库函数`qsort()`进行排序的方法,适用于不同数据类型和复杂结构的...通过上述示例,读者应能充分理解并应用`qsort()`于实际问题中,提高程序的性能和功能。
### qsort函数详解与应用实例 #### 引言 `qsort`是C语言标准库中的一个强大排序函数,它提供了灵活的通用性,能够处理各种数据类型和复杂度的数据结构排序需求。`qsort`函数的核心优势在于其比较函数参数,这允许...
C 库函数 qsort 七种使用方法示例 本文将对 C 库函数 qsort 进行详细的介绍,并提供七种使用方法示例,...通过本文的示例代码,可以帮助 C 语言初学者快速掌握 qsort 函数的使用方法,并且可以应用于实际的编程中。