1.先简单调用C语言封装好的冒泡排序
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
//qsort C语言封装好的冒泡排序 可比较任何类型
struct stu{char name[20];int age;
};
//用户自己写的函数。函数名字也作为函数指针使用。是qsort函数的第四个参数
// void *代表可以接受任意类型的地址 但由于不清楚所占字节 所以不能对void*进行解引用和加减整数操作
//指针类型决定解引用时所访问空间大小 也决定指针加减整数时移动多大内存
int Compare_st(const void *e1,const void *e2)
{return strcmp(((struct stu*)e1)->name,((struct stu*)e2)->name);//想要对什么数据进行比较 就强制转换为什么类型的指针
}
int main(){struct stu a [3]={{"zhangsan",20},{"lisi",10},{"wangwu",15}};int leng=sizeof(a)/sizeof(a[0]);qsort(a,leng,sizeof(a[0]),Compare_st);//第一个参数为需排序数组首元素 第二个参数为需排序数组长度 第三个参数为需排序数组一个元素的大小 第四个参数为想要如何排序的函数(用户自己写的)的指针for(int x=0;x<3;x++){printf("%s %d ",a[x].name,a[x].age);}return 0;
}
2.代码实现比较任意类型的冒泡排序(排序结构体字符串)
#include<stdio.h>
#include<stdlib.h>
#include<string.h>struct stu{char name[20];int age;
};void swap(char*a,char* b,int awidth){int i=0;//一次比较按照字符对内容进行交换for(i=0;i<awidth;i++){char temp=*a;*a=*b;*b=temp;a++;b++;}}int Compare_st(const void *e1,const void *e2)
{return strcmp(((struct stu*)e1)->name,((struct stu*)e2)->name);//想要对什么数据进行比较 就强制转换为什么类型的指针
}//第一个参数为需排序数组首元素地址 第二个参数为需排序数组长度 第三个参数为需排序数组一个元素的大小
// 第四个参数为想要如何排序的函数(用户自己写的)的指针
void test_qsort(void *a,int leng,int awidth,int(* Compare)( void *e1, void *e2)){int i=0;int j=0;//普通冒泡排序双层循环for(i=0;i<leng-1;i++){//比较趟数for(j=0;j<leng-1-i;j++){//一趟比较次数if(Compare((char *)a+j*awidth,(char *)a+(j+1)*awidth)>0)//将数组内容传到用户写的函数里进行比较 >0升序排列//(char *)a+j*awidth和(char *)a+(j+1)*awidth两个参数 强制转换为(char*)//(char*)+1 跳过一个字节 +2跳过两个字节.... 比较容易操作任意类型//假如 数组现在是987654321 这两个参数就是9和8 下次循环就是8和7swap((char *)a+j*awidth,(char *)a+(j+1)*awidth,awidth);//交换内容}}
}int main(){struct stu a [3]={{"zhangsan",20},{"lisi",10},{"wangwu",15}};int leng=sizeof(a)/sizeof(a[0]);test_qsort(a,leng,sizeof(a[0]),Compare_st);//模拟C语言的任意冒泡排序//第一个参数为需排序数组首元素 第二个参数为需排序数组长度 //第三个参数为需排序数组一个元素的大小 第四个参数为想要如何排序的函数(用户自己写的)的指针for(int x=0;x<3;x++){printf("%s %d ",a[x].name,a[x].age);}return 0;
}