qsort()快排

来源:互联网 发布:进入mysql数据库表命令 编辑:程序博客网 时间:2024/05/16 06:22


快排sqort()

//部分验证,推理得出。内容基本可靠!

////////////////////对int/char/float/double整形数组的快排/////////////////////

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

int cmp(const void *p,const void *q)//该函数进行的是升序快排,如果想要进行降序快排,则将1和-1调换即可

{

return *(元素类型 *)p>*(元素类型 *)q?1:-1;//根据元素的值进行排序

}

int main()

{

元素类型 str[V]; //V为数组大小

          qsort(strcntsizeof(num[0]), cmp);//元素类型型数组str[ ]进行快排//cnt为要排的元素的个数

}

///////////////////////////////////////////////////////////////////////////////

///////////////////////////////对结构体某元素的快排////////////////////////////

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

int cmp(const void *p, const void *q);//声明函数

struct ln

{

          int data;

          int score;

          int math;

}ss[V];//V为数组大小

int main()

{

          qsort(ss, cnt sizeof(struct ln), cmp);//对结构体ss进行快排//cnt为要排的元素的个数

}

int cmp(const void *p,const void *q)//该函数进行的是升序快排,如果想要进行降序快排,则将1和-1调换即可

{

    return (*(struct ln*)p).data>(*(struct ln*)q).data?1:-1;//根据结构体中data的值进行排序

 

}//一级结构体排序

 

int cmp(const void *p,const void *q)//该函数进行的是升序快排,如果想要进行降序快排,则将1和-1调换即可

{

if((*(struct ln*)p).data==(*(struct ln*)q).data)//结构体中data的值相等

return (*(struct ln*)p).score>(*(struct ln*)q).score?1:-1;//根据结构体中score的值进行排序

 

else

     return (*(struct ln*)p).data>(*(struct ln*)q).data?1:-1;//根据结构体中data的值进行排序

 

}//二级结构体排序

 

//多级结构体以此类推

///////////////////////////////////////////////////////////////////////////////

//////////////////////////////结构体重字符串的快排///////////////////////////

#include <stdio.h>

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

struct ln

{

int data;

char ch[v];//v为数组大小

}ss[V];//V为数组大小

int cmp(const void *p,const void *q)

{

return strcmp((*(struct ln*)p).ch,(*(struct ln*)q).ch );

}

int main()

{

qsort(ss,cnt,sizeof(ss[0]),cmp);//对结构体ss按照结构体中字符串ch的字典顺序进行快排//cnt为要排的元素的个数

}

///////////////////////////////////////////////////////////////////////////////

//////////////////////////////////注意事项/////////////////////////////////////

1.根据实际操作发现qsort在排非常大(或非常小)的数(如<limits.h>中的INT_MAX(INT_MIN))时会失灵(不排这个数),原因暂不明,使用时要注意!

2.使用qsort应用.c编辑,不可用.cpp!


原文链接:http://blog.sina.com.cn/s/blog_99d77d1301011ru2.html

0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 一年级孩子上课说话不听课怎么办 一年级孩子上课不听课怎么办 小学一年级学生上课不专心怎么办? 小孩听课注意力不集中怎么办 小孩子上课精神不集中怎么办 孩子说我不画了怎么办 幼儿园小朋友上课不专心怎么办 孩子写作业不专心怎么办 小孩做作业不专心怎么办 孩子上课精力不集中怎么办 四岁宝宝吃饭慢怎么办 5岁宝宝吃饭慢怎么办 小学一年级上课不专心怎么办 5岁儿童不专心怎么办 小孩子做作业不专心怎么办 孩子做作业不专心怎么办 小孩学了就忘怎么办 小孩学过就忘了怎么办 做事老是注意力不集中怎么办 做事无法专注注意力不集中怎么办 幼儿园孩子上课不认真听讲怎么办 孩子在课间打闹家长应该怎么办 孩子打闹家长额钱怎么办 我又打孩子了怎么办 打排卵针不排卵怎么办 总是控制不住打骂孩子怎么办 叛逆期的孩子打骂妈妈怎么办 孩子屁股打青了怎么办 父亲把孩子屁股打流血怎么办 孩子屁股长了湿疹怎么办 宝宝发脾气摔东西躺地上怎么办 生气拿棍子打了孩子怎么办 小宝宝被蚊虫咬了怎么办 小宝宝被蚊子咬了怎么办 衣架打小孩淤青怎么办 1岁宝宝有痰咳嗽怎么办 1岁宝宝咳嗽有痰怎么办 孩子爱动手打家长怎么办 不小心有了孩子该怎么办 2岁多宝宝干咳怎么办 2岁宝宝咳嗽无痰怎么办