本文實例為大家分享了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);}
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。
新聞熱點
疑難解答
圖片精選