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;
}
相关推荐
李永奉2 小时前
C语言-指针初级(指针定义、指针的作用、指针的计算、野指针、悬空指针、void类型指针)
c语言·开发语言
愤怒的小鸟~~~6 小时前
c语言创建的一个队列结构(含有这个头指针和这个尾指针的结构具有一定的参考价值)
c语言·开发语言·算法
重生之我是Java开发战士9 小时前
【C语言】内存函数与数据在内存中的存储
c语言·开发语言·算法
Hello_Embed10 小时前
嵌入式 C 语言入门:循环结构学习笔记 —— 从语法到实用技巧
c语言·笔记·stm32·学习
南棱笑笑生11 小时前
20250802让飞凌OK3576-C开发板在飞凌的Android14下【rk3576_u选项】适配NXP的WIFIBT模块88W8987A的蓝牙
c语言·开发语言
tju新生代魔迷14 小时前
C语言:位段作业
c语言·开发语言
遇见尚硅谷16 小时前
# C语言:20250730学习(二级指针)
c语言·学习·算法
银河码17 小时前
嵌入式linux驱动开发:什么是Linux驱动?深度解析与实战入门
linux·c语言·驱动开发·驱动入门
爱吃KFC的大肥羊18 小时前
C/C++常用字符串函数
c语言·数据结构·c++·算法
阿捏利18 小时前
C Primer Plus 第6版 编程练习——第15章
c语言·c primer plus