C语言 快速排序函数
发布日期:2021-06-29 19:13:44
浏览次数:3
分类:技术文章
本文共 1104 字,大约阅读时间需要 3 分钟。
C语言 快速排序函数用法
#include#include #include struct student{ int id; char name[12]; char sex;};int compare(const void* a,const void* b)//基本数据类型排序{ return *(char*)a-*(char*)b;//从小到大 //取值//强转为相应类型的指针!!}int compare_struct(const void* a,const void* b){ return (*(struct student*)a).id-((struct student*)b)->id; //注意优先级诶!//否则报错在非结构体中。。。}int compare_struct_duoji(const void* a,const void* b)//多级排序{ struct student student_a=*(struct student*)a; struct student student_b=*(struct student*)b; if(student_a.id==student_b.id) { return student_a.sex-student_b.sex; } else { return student_a.id-student_b.id; }}void main(){//*************char型************* char a[5]="hello"; qsort(a,5,sizeof(a[0]),compare); //元素个数//元素大小//函数指针 int i; for(i=0;i<5;i++) printf("%c ",a[i]); printf("\n"); //************struct型************ struct student e[4]={ {100,"chen",'m'},{100,"li",'f'}, \ {70,"wang",'f'},{100,"zhang",'m'}}; qsort(e,4,sizeof(e[1]),compare_struct_duoji); for(i=0;i<4;i++) printf("%d %s %c\n",e[i].id,e[i].name,e[i].sex);}
转载地址:https://czhenya.blog.csdn.net/article/details/77948322 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
能坚持,总会有不一样的收获!
[***.219.124.196]2024年04月21日 00时01分03秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
第二个MacBook,继续加油!
2019-04-30
unittest source code learning
2019-04-30
故障处理_vxwork 大端序和变量指针
2019-04-30
写在前面的话
2019-04-30
数据结构学习_树(1)
2019-04-30
数据结构学习_树(2)
2019-04-30
数据结构学习_树(3)
2019-04-30
数据结构学习_树(4)
2019-04-30
数组与矩阵(1)_矩阵相乘
2019-04-30
数据结构学习_图(1)深度优先搜索、广度优先搜索和最小生成树
2019-04-30
数据结构学习_图(1)拓扑排序
2019-04-30
利用Strategy模式方便的增加新定义的操作
2019-04-30
command模式(c 语言实现)
2019-04-30
state 模式(c++ 实现)
2019-04-30
打印图形
2019-04-30
新的开始
2019-04-30
dos下常用网络命令
2019-04-30
powerpc汇编指令分析
2019-04-30
欢迎使用CSDN-markdown编辑器
2019-04-30