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;
}
相关推荐
OOJO14 小时前
c++---list介绍
c语言·开发语言·数据结构·c++·算法·list
笨笨饿16 小时前
29_Z变换在工程中的实际意义
c语言·开发语言·人工智能·单片机·mcu·算法·机器人
艾为电子16 小时前
【技术帖】让接口不再短命:艾为 C-Shielding™ Type-C智能水汽防护技术解析
c语言·开发语言
笨笨饿18 小时前
30_泰勒级数
c语言·stm32·嵌入式硬件·线性代数·机器学习·自动化·概率论
OOJO19 小时前
c++---vector介绍
c语言·开发语言·数据结构·c++·算法·vim·visual studio
爱编码的小八嘎21 小时前
C语言完美演绎6-21
c语言
爱编码的小八嘎1 天前
c.语言完美演绎6-22
c语言
不爱吃炸鸡柳1 天前
[特殊字符]C/C++内存管理深度解剖:从内存布局到new/delete底层,吃透面试必考核心
c语言·c++·面试
Lzh编程小栈1 天前
数据结构与算法之队列深度解析:循环队列+C 语言硬核实现 + 面试考点全梳理
c语言·开发语言·汇编·数据结构·后端·算法·面试
凉、介1 天前
Flash 块设备驱动开发
c语言·驱动开发·笔记·学习·操作系统·嵌入式