首页IT科技C语言中qSort函数(qsort函数的用法 菜鸟的日志 网易博客)

C语言中qSort函数(qsort函数的用法 菜鸟的日志 网易博客)

时间2025-05-04 17:51:46分类IT科技浏览3789
导读:六类qsort排序方法 前一段时间做题觉得qsort函数很好用,但有时不太会用比如按结构体一级排序、二级排序、字符串排序等,故通过查...

六类qsort排序方法

前一段时间做题觉得qsort函数很好用           ,但有时不太会用比如按结构体一级排序           、二级排序                、字符串排序等                ,故通过查资料将其整理一番           。

以下是其具体分类及用法(若无具体说明是以降序排列):

1     、对一维数组排序:

(Element_type是一位数组中存放的数据类型     ,可以是char, int, float, double, etc )

int Comp(const void *p1,const void *p2 ) { return *((Element_type *)p2) > *((Element_type *)p1) ? 1 : -1; } int main() { Element_type list[MAX]; initial(list); qsort(list, sizeof(list),sizeof(Element_type),Comp); return 0; }

复制代码

2           、对字符串排序:

int Comp(const void *p1,const void *p2) { return strcmp((char *)p2,(char *)p1); } int main() { char a[MAX1][MAX2]; initial(a); qsort(a,lenth,sizeof(a[0]),Comp); //lenth 为数组a的长度

复制代码

3                 、按结构体中某个关键字排序(对结构体一级排序):

struct Node { double data; int other; }s[100]; int Comp(const void *p1,const void *p2) { return (*(Node *)p2).data > (*(Node *)p1).data ? 1 : -1; } qsort(s,100,sizeof(s[0]),Comp);

复制代码

4     、按结构体中多个关键字排序(对结构体多级排序)[以二级为例]:

struct Node { intx; int y; }s[100]; //按照x从小到大排序      ,当x相等时按y从大到小排序 int Comp(const void *p1,const void *p2) { struct Node*c = (Node *)p1; struct Node *d = (Node *)p2; if(c->x != d->x) return c->x-d->x; else return d->y - c->y; }

复制代码

5     、对结构体中字符串进行排序:

struct Node { int data; char str[100]; }s[100]; //按照结构体中字符串 str 的字典序排序 int Comp(const void *p1,const void *p2) { return strcmp((*(Node *)p1).str,(*(Node *)p2).str); } qsort(s,100,sizeof(s[0],Comp);

复制代码

6                 、计算几何中求凸包的Comp

//以下是俺从别人那儿抄来的                ,暂时还没用过 int Comp(const void *p1,const void *p2) //重点Comp函数           ,把除了1点外的所有的点旋转角度排序 { struct point*c=(point *)p1; struct point *d=(point *)p2; if( cacl(*c, *d,p[1]) < 0) return 1; else if(!cacl(*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; elsereturn -1; }

复制代码

P.S.:qsort函数是ANSIC标准中提供的                ,其声明在stdlib.h文件中           ,是根据二分发写的,其时间复杂度为n*log(n),其结构为:

void qsort(void *base,size_t nelem,size_t width,int (*Comp)(const void *,const void *));

复制代码

其中:

*base 为要排序的数组

nelem 为要排序的数组的长度

width 为数组元素的大小(一字结为单位)

(* Comp)(const void *p1,const void *p2) 为判断大小函数的指针                ,这个函数需要自己定义                ,如果p1>p2,函数返回-1;a<b,函数返回1;a==b函数返回0                。

声明:本站所有文章,如无特殊说明或标注           ,均为本站原创发布     。任何个人或组织                ,在未征得本站同意时     ,禁止复制           、盗用     、采集                、发布本站内容到任何网站           、书籍等各类媒体平台           。如若本站内容侵犯了原著者的合法权益           ,可联系我们进行处理                 。

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
帝国cms好用吗(帝国cms可以做商城么) win7清理电脑c盘内存怎么清(在WIN7中,如何清理C盘空间?)