六狼论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博账号登陆

只需一步,快速开始

搜索
查看: 31|回复: 0

六种qsort排序方法

[复制链接]

升级  5.33%

16

主题

16

主题

16

主题

秀才

Rank: 2

积分
58
 楼主| 发表于 2013-1-26 12:32:34 | 显示全部楼层 |阅读模式
<本文中排序都是采用的从小到大排序>

一、对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 - *(int *)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);


PS:

其中的qsort函数包含在<stdlib.h>的头文件里,strcmp包含在<string.h>的头文件里
您需要登录后才可以回帖 登录 | 立即注册 新浪微博账号登陆

本版积分规则

快速回复 返回顶部 返回列表