C语言 简单使用qsort 比较结构体字符串大小

1.先简单调用C语言封装好的冒泡排序

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.代码实现比较任意类型的冒泡排序(排序结构体字符串)

c 复制代码
#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和7
              swap((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;
}
相关推荐
剑心诀16 小时前
02 数据结构(C) | 线性表——顺序表的基本操作
c语言·开发语言·数据结构
m0_4886333216 小时前
Windows环境下编译运行C语言程序,合适工具与方法很关键
c语言·windows·git·开发工具·编译器
m0_4886333216 小时前
C语言变量命名规则、入门自学、运算符优先级及数据结构介绍
c语言·数据结构·运算符优先级·变量命名·入门自学
Book思议-17 小时前
【数据结构实战】川剧 “扯脸” 与栈的 LIFO 特性 :用 C 语言实现 3 种栈结构
c语言·数据结构·算法·
炸膛坦客19 小时前
单片机/C/C++八股:(二十一)include <> 和 include ““ 的区别
c语言·c++
Yupureki19 小时前
《Linux系统编程》12.基础IO
linux·运维·c语言·开发语言·数据库·c++
炸膛坦客19 小时前
单片机/C/C++八股:(十八)C/C++ 中 sizeof 和 strlen 的区别
c语言·c++
看山是山_Lau20 小时前
代码命名规范原则与原理
c语言·开发语言
计算机安禾21 小时前
【数据结构与算法】第6篇:线性表(二):单链表的实现(头插法、尾插法)
c语言·数据结构·学习·算法·链表·visual studio code·visual studio
计算机安禾1 天前
【数据结构与算法】第5篇:线性表(一):顺序表(ArrayList)的实现与应用
c语言·开发语言·数据结构·c++·算法·visual studio code·visual studio