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;
}
相关推荐
l1t1 小时前
利用DeepSeek实现服务器客户端模式的DuckDB原型
服务器·c语言·数据库·人工智能·postgresql·协议·duckdb
l1t3 小时前
利用美团龙猫用libxml2编写XML转CSV文件C程序
xml·c语言·libxml2·解析器
Gu_shiwww9 小时前
数据结构8——双向链表
c语言·数据结构·python·链表·小白初步
你怎么知道我是队长10 小时前
C语言---循环结构
c语言·开发语言·算法
程序猿编码11 小时前
基于 Linux 内核模块的字符设备 FIFO 驱动设计与实现解析(C/C++代码实现)
linux·c语言·c++·内核模块·fifo·字符设备
mark-puls13 小时前
C语言打印爱心
c语言·开发语言·算法
西阳未落13 小时前
C语言柔性数组详解与应用
c语言·开发语言·柔性数组
小莞尔15 小时前
【51单片机】【protues仿真】基于51单片机数控直流稳压电源系统
c语言·stm32·单片机·嵌入式硬件·51单片机
小莞尔15 小时前
【51单片机】【protues仿真】基于51单片机密码锁系统
c语言·stm32·单片机·嵌入式硬件·51单片机
用户61204149221316 小时前
C语言做的停车场管理系统
c语言·后端·敏捷开发