C语言快速排序函数用法(qsort)
2017-08-24 09:41
603 查看
本文实例为大家分享了C语言快排函数用法,供大家参考,具体内容如下
#include <stdio.h> #include <stdlib.h> #include <string.h> 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); }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- C/C++程序员:排序算法之标准C语言qsort函数简单用法介绍
- C语言qsort的用法
- C语言qsort的用法
- C++ sort和C语言qsort用法对比
- C语言qsort的用法
- C语言qsort的用法和使用
- C语言里的快排函数用法(qsort)
- C语言qsort和C++sort的用法小结和区别比较
- C语言qsort函数用法
- c语言的模板 qsort 的用法
- C语言qsort的用法
- C语言中qsort的基本用法
- C语言switch语句的用法详解
- C语言中enum类型的用法
- 快速排序函数sort和qsort
- C语言中的字符串分割函数strtok的用法
- qsort 函数用法
- c语言学习笔记(7)单引号,双引号和逻辑符号的用法
- 关于c语言的typedef高级用法 typedef void (*post_sync_t)(CO_Data*);
- C语言中可变参数的用法