zoukankan      html  css  js  c++  java
  • qsort函数的用法 菜鸟的日志 网易博客

    qsort函数的用法 - 菜鸟的日志 - 网易博客

    qsort函数的用法   

    2011-03-28 16:11:26|  分类: 默认分类 |  标签:  |字号 订阅

    六类qsort排序方法

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

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

    1、对一维数组排序:

    (Element_type是一位数组中存放的数据类型,可以是char, int, float, double, etc )
    1. int Comp(const void *p1,const void *p2 )
    2. {
    3. return *((Element_type *)p2) > *((Element_type *)p1) ? 1 : -1;
    4. }
    5. int main()
    6. {
    7. Element_type list[MAX];
    8. initial(list);
    9. qsort(list, sizeof(list),sizeof(Element_type),Comp);
    10. return 0;
    11. }
    复制代码

    2、对字符串排序:
    1. int Comp(const void *p1,const void *p2)
    2. {
    3. return strcmp((char *)p2,(char *)p1);
    4. }
    5. int main()
    6. {
    7. char a[MAX1][MAX2];
    8. initial(a);
    9. qsort(a,lenth,sizeof(a[0]),Comp);
    10. //lenth 为数组a的长度
    复制代码

    3、按结构体中某个关键字排序(对结构体一级排序):
    1. struct Node
    2. {
    3. double data;
    4. int other;
    5. }s[100];
    6. int Comp(const void *p1,const void *p2)
    7. {
    8. return (*(Node *)p2).data > (*(Node *)p1).data ? 1 : -1;
    9. }
    10. qsort(s,100,sizeof(s[0]),Comp);
    复制代码

    4、按结构体中多个关键字排序(对结构体多级排序)[以二级为例]:
    1. struct Node
    2. {
    3. int  x;
    4. int y;
    5. }s[100];
    6. //按照x从小到大排序,当x相等时按y从大到小排序
    7. int Comp(const void *p1,const void *p2)
    8. {
    9. struct Node  *c = (Node *)p1;
    10. struct Node *d = (Node *)p2;
    11. if(c->x != d->x) return c->x-d->x;
    12. else return d->y - c->y;
    13. }
    复制代码

    5、对结构体中字符串进行排序:
    1. struct Node
    2. {
    3. int data;
    4. char str[100];
    5. }s[100];
    6. //按照结构体中字符串 str 的字典序排序
    7. int Comp(const void *p1,const void *p2)
    8. {
    9. return strcmp((*(Node *)p1).str,(*(Node *)p2).str);
    10. }
    11. qsort(s,100,sizeof(s[0],Comp);
    复制代码

    6、计算几何中求凸包的Comp
    1. //以下是俺从别人那儿抄来的,暂时还没用过
    2. int Comp(const void *p1,const void *p2)
    3. //重点Comp函数,把除了1点外的所有的点旋转角度排序
    4. {
    5. struct point  *c=(point *)p1;
    6. struct point *d=(point *)p2;
    7. if( cacl(*c, *d,p[1]) < 0) return 1;
    8. 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 ) )
    9. //如果在一条直线上,则把远的放在前面
    10. return 1;
    11. else  return -1;
    12. }
    复制代码

    P.S.:qsort函数是ANSI  C标准中提供的,其声明在stdlib.h文件中,是根据二分发写的,其时间复杂度为n*log(n),其结构为:
    1. 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。
  • 相关阅读:
    www.verycd.com
    HDU-5281
    HDU-5280
    UVALive 6426
    hihocoder 1178 : 计数
    hihocoder 1177 : 顺子
    HDU-5272
    Tomcat 部署项目的三种方法
    Oracle数据库PLSQL的中文乱码显示全是问号
    ORACLE的sign函数和DECODE函数
  • 原文地址:https://www.cnblogs.com/lexus/p/2591092.html
Copyright © 2011-2022 走看看