zoukankan      html  css  js  c++  java
  • (转)六类qsort排序方法

    转自http://hi.baidu.com/zhangwp999/blog/item/185f9afba454ba63024f5675.html

    *六类qsort排序方法

    P.S.:qsort函数是ANSI   C标准中提供的,其声明在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。

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

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

    例子1:对一维数组进行排序

    #include <stdio.h>
    #include <stdlib.h>
    int Comp(const void *p1,const void *p2 )

    {

    return *((int *)p1) - *((int *)p2);

    }

    int main()

    {
    int list[100];

    for(int i=0;i<10;i++)
       scanf("%d",&list[i]);
    qsort(list, 10,sizeof(int),Comp);
    for(int i=0;i<10;i++)
       printf("%d ",list[i]);
    system("pause");
    return 0;

    }

    例子2:对字符串进行排序
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    int Comp(const void *p1,const void *p2)

    {

    return strcmp((char *)p1,(char *)p2);

    }

    int main()

    {
    char a[100][100];
    for(int i=0;i<3;i++)
       gets(a[i]);
    qsort(a,3,sizeof(a[0]),Comp);
    for(int i=0;i<3;i++)
       puts(a[i]);
    system("pause");
    return 0;

    }


    例子3:按结构体中某个关键字排序(对结构体一级排序):
    #include <stdio.h>
    #include <stdlib.h>
    struct ab
    {
    int vote1;
    int id;
    }abc[6];

    int cmp(const void *a, const void *b)
    {
    return ((struct ab *)a)->vote1-((struct ab *)b)->vote1;
    }

    int main()
    {
    for(int i = 0; i < 5; i++)
       scanf("%d",&abc[i].vote1);
    qsort((void *)abc,5,sizeof(abc[0]),cmp);
    for(int i=0;i<5;i++)
         printf("%d ",abc[i]);

    system("pause");
    return 0;
    }

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


    #include <stdio.h>
    #include <stdlib.h>

    struct ab
    {
    int x;
    int y;
    }abc[6];

    int cmp(const void *a, const void *b)
    {
        if(((struct ab *)a)->x!=((struct ab *)b)->x)
               return ((struct ab *)a)->x-((struct ab *)b)->x;
        else
               return ((struct ab *)a)->y-((struct ab *)b)->y;
    }

    int main()
    {
    for(int i = 0; i < 5; i++)
    {
    scanf("%d%d",&abc[i].x,&abc[i].y);
    }
    qsort((void *)abc,5,sizeof(abc[0]),cmp);
    for(int i=0;i<5;i++)
       printf("%d %d ",abc[i].x,abc[i].y);

    system("pause");
    return 0;
    }


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

    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>

    struct ab
    {
    int x;
    char ac[100];
    }abc[6];


    int cmp(const void *a, const void *b)
    {
    return strcmp(((struct ab *)a)->ac,((struct ab *)b)->ac);
    }

    int main()
    {
    for(int i = 0; i < 5; i++)
    {
    gets(abc[i].ac);
    }
    qsort((void *)abc,5,sizeof(abc[0]),cmp);
    for(int i=0;i<5;i++)
    puts(abc[i].ac);

    system("pause");
    return 0;
    }

    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;

    else   return -1;

    }


    再次P.S.:qsort函数是ANSI   C标准中提供的,其声明在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。

    //////////////
    又见qsort--------zju2727
    一道按给定关键字三级排序题,直接套入曾总结过的qsort模型就AC了。算是上次总结的一个补充实例吧。
    源代码:
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>

    struct Node{
         char Name[100];
         int Year,Price;
    }Book[100];
    /*----------------------------------------------------------------------------*/
    /*int CompY(const void *p1,const void *p2)//首先按year排序
         {
             struct Node   *c = (Node *)p1;
             struct Node *d = (Node *)p2;
             if(c->Year != d->Year) return c->Year-d->Year;
             else if(strcmp((*(Node *)p1).Name,(*(Node *)p2).Name))
                 return strcmp((*(Node *)p1).Name,(*(Node *)p2).Name);
             else return c->Price-d->Price;
         }

    int CompP(const void *p1,const void *p2)//首先按price排序
         {
             struct Node   *c = (Node *)p1;
             struct Node *d = (Node *)p2;
             if(c->Price != d->Price) return c->Price-d->Price;
             else if(strcmp((*(Node *)p1).Name,(*(Node *)p2).Name))
                 return strcmp((*(Node *)p1).Name,(*(Node *)p2).Name);
             else return c->Year-d->Year;
         }
        
    int CompN(const void *p1,const void *p2)//首先按name排序
         {
             struct Node   *c = (Node *)p1;
             struct Node *d = (Node *)p2;
             if(strcmp((*(Node *)p1).Name,(*(Node *)p2).Name))
                 return strcmp((*(Node *)p1).Name,(*(Node *)p2).Name);
             else if(c->Year != d->Year) return c->Year-d->Year;
             else return c->Price-d->Price;
         }    
    /*-------------------------------------------------------------------*/        
    /*void outres(int n)
    {
         int i;
         for(i=0;i<n;i++)
             printf("%s %d %d\n",Book[i].Name,Book[i].Year,Book[i].Price);
    }
    /*-----------------------------------------------------------------*/
    /*int main()
    {
         int n;
         char format[15];
         //freopen("in.txt","r",stdin);
         scanf("%d",&n);
         while(n)
         {
             for(int i=0;i<n;i++)
                 scanf("%s%d%d",Book[i].Name,&Book[i].Year,&Book[i].Price);
             scanf("%s",format);
             if(format[0]=='Y')
             {
                 qsort(Book, n, sizeof(Book[0]), CompY);
             }
             else if(format[0]=='P')
             {
                 qsort(Book, n, sizeof(Book[0]), CompP);
             }
             else
             {
                 qsort(Book, n, sizeof(Book[0]), CompN);
             }

             outres(n);
             scanf("%d",&n);
             if(n)printf("\n");
         }
         return 0;
    }

    */

    poj3664

    #include <stdio.h>
    #include <stdlib.h>
    structab
    {
    int vote1;
    int vote2;
    int id;
    }abc[1000000];

    int cmp1(const void *a, const void *b)
    {
    return ((structab *)a)->vote1-((structab *)b)->vote1;
    }
    int cmp2(const void *a,const void *b)
    {
    return ((structab *)a)->vote2-((structab *)b)->vote2;
    }

    int main()
    {
    int i,j,k;
    scanf("%d%d",&j,&k);
    for(i = 0; i < j; i++)
    {
    scanf("%d%d",&abc[i].vote1, &abc[i].vote2);
    abc[i].id = i + 1;
    }
    qsort((void *)abc,j,sizeof(abc[0]),cmp1);
    qsort((void *)(&abc[j-k]),k,sizeof(abc[0]),cmp2);
    printf("%d\n",abc[j-1].id);

    //system("pause");
    return 0;
    }

      

  • 相关阅读:
    JavaScript学习笔记(十六) XMLHttpRequest
    Zabbix 3.0 安装笔记
    jetty端口灵活配置方法
    IDEA15入门常用设置
    [转] 填石头——时间管理
    [转]关于产品的落地
    [转]Netbeans IDE默认UTF-8编码
    如何解决SSH连接Linux超时自动断开?
    ActiveMQ部署步骤和后台管理网站Service Unavailable问题解决笔记
    [转]Maven2中snapshot快照库的使用
  • 原文地址:https://www.cnblogs.com/shangyu/p/2587201.html
Copyright © 2011-2022 走看看