qsort函数的使用及其模拟实现

一.基本介绍

注意:qsort函数是默认从小到大排序

二、qsort 函数的使用

1.排序数组

cpp 复制代码
int compare(const void* e1, const void* e2)
{
    return  *(int*)e1 - *(int*)e2;//强制类型转换
}

int main()
{
    int arr[10] = { 44,5,34,56,42,90,43,1,52,98 };
    int num = sizeof(arr) / sizeof(arr[0]);
    int sz = sizeof(arr[0]);
    qsort(&arr[0], num, sz, compare);
    for (int i = 0; i < num; i++)
    {
        printf("%d ", arr[i]);
    }
    return 0;
}

结果:

2.排序结构体

(1)按结构体中的数字排序

cpp 复制代码
struct stu
{
    int age;
    char name[20];
}arr[3];


int compare(const void* e1, const void* e2)
{
    return  ((struct stu*)e1)->age - ((struct stu*)e2)->age;//强制类型转换
}

int main()
{
    struct stu arr[3] = { {13,"zhouzisong"},{12,"zhouzihao"},{20,"fengcheng"} };
    int num = sizeof(arr) / sizeof(arr[0]);
    int sz = sizeof(arr[0]);
    qsort(&arr[0], num, sz, compare);
    for (int i = 0; i < num; i++)
    {
        printf("%d %s\n",arr[i].age,arr[i].name);
    }
    return 0;
}

结果:

(2)按结构体中的字符串排序

cpp 复制代码
struct stu
{
    int age;
    char name[20];
}arr[3];


int compare_by_name(const void* e1, const void* e2)
{
    return  strcmp(((struct stu*)e1)->name , ((struct stu*)e2)->name);//强制类型转换
}


int main()
{
    struct stu arr[3] = { {13,"zhouzisong"},{12,"zhouzihao"},{20,"fengcheng"} };
    int num = sizeof(arr) / sizeof(arr[0]);
    int sz = sizeof(arr[0]);
    qsort(&arr[0], num, sz, compare_by_name);
    for (int i = 0; i < num; i++)
    {
        printf("%d %s\n",arr[i].age,arr[i].name);
    }
    return 0;
}

结果:

三、qsort 函数模拟实现

cpp 复制代码
struct stu
{
    int age;
    char name[20];
}arr[3];


int compare(const void* e1, const void* e2)
{
    return  ((struct stu*)e1)->age - ((struct stu*)e2)->age;//强制类型转换
}

int compare_by_name(const void* e1, const void* e2)
{
    return  strcmp(((struct stu*)e1)->name , ((struct stu*)e2)->name);//强制类型转换
}

void swap(char* bulf1, char* bulf2,int sz)
{
    int i;
    char temp;
    for (i = 0; i < sz; i++)
    {
        temp = *bulf1;
        *bulf1 = *bulf2;
        *bulf2 = temp;
        bulf1++;
        bulf2++;
    }
}

void my_qsort(void* base, size_t num, size_t sz, int (*cmp)(const void* e1, const void* e2))
{
    int i, j;
    for (i = 0; i < num - 1; i++)
    {
        for (j = 0; j < num - 1 - i; j++)
        {
            if (cmp((char*)base + j * sz, (char*)base + (j + 1) * sz) > 0)
            {
                swap( (char*)base + j * sz, (char*)base + (j + 1) * sz,sz);
            }
        }
    }
}

int main()
{
    struct stu arr[3] = { {13,"zhouzisong"},{12,"zhouzihao"},{20,"fengcheng"} };
    int num = sizeof(arr) / sizeof(arr[0]);
    int sz = sizeof(arr[0]);
    //my_qsort(&arr[0], num, sz, compare);
    my_qsort(&arr[0], num, sz, compare_by_name);
    for (int i = 0; i < num; i++)
    {
        printf("%d %s\n",arr[i].age,arr[i].name);
    }
    return 0;
}
相关推荐
芯联智造4 分钟前
【stm32简单外设篇】- WS2812单线地址式 RGB 灯带
c语言·stm32·单片机·嵌入式硬件
djarmy3 小时前
ubuntu20.04搭建openharmony6.0的master分支。构建编译环境报错解决记录
c语言·ubuntu
竹烟淮雨5 小时前
C语言指针概念详解:数组指针与二级指针的本质区别
c语言
senijusene7 小时前
用C语言制作一个简易HTTP服务器:实现手机商城用户认证与搜索
服务器·c语言·http
Aaswk7 小时前
蓝桥杯2025年第十六届省赛真题(更新中)
c语言·数据结构·c++·算法·职场和发展·蓝桥杯
香水5只用六神8 小时前
【DMA】存储器到外设模式实验2
c语言·git·stm32·单片机·嵌入式硬件·github·visual studio
Yupureki8 小时前
《C++实战项目-高并发内存池》4.CentralCache构造
c语言·开发语言·c++·单例模式·github
xh didida9 小时前
数据结构--实现链式结构二叉树
c语言·数据结构·算法
祈安_10 小时前
动态内存管理(上)
c语言·后端
进击的小头10 小时前
第8篇:PI控制器设计实战演练
c语言·python·mcu·算法