Project回调函数qsort②进阶应用

embedded/2025/3/16 15:42:43/

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<string.h>
//库函数strcmp头文件
//使用qsort排序结构体

struct Stu
{
    char name[20];
    int age;
};

//按照年龄排序
int cmp_stu_by_age(const void* e1,const void* e2)
{
    return ((struct Stu*)e1)->age - ((struct Stu*)e2)->age;

    //错误写法:return *((struct Stu*)e1)->age - *((struct Stu*)e2)->age;
    //错误原因:((struct Stu*)e1)->age,((struct Stu*)e2)->age 已经拿到结构体数组元素了,
    //            不需要再用解引用 * 通过地址去找它们。

}
//按照名字排序
int cmp_stu_by_name(const void* e1, const void* e2)
{
    return strcmp(((struct Stu*)e1)->name, ((struct Stu*)e2)->name);

    //库函数:strcmp
    //比较字符串大小

}
int main()
{
    struct Stu s[3] = { {"wanger",45},{"zhangsan",20},{"lisi",19} };
    int sz = sizeof(s) / sizeof(s[0]);
    qsort(s, sz, sizeof(s[0]), cmp_stu_by_age);
    int i = 0;
    for(i=0;i<sz;i++)
    {
        printf("name: %s,age: %d\n", s[i].name, s[i].age);
    }
    printf("\n");
    qsort(s, sz, sizeof(s[0]), cmp_stu_by_name);
    for (i = 0; i < sz; i++)
    {
        printf("name: %s,age: %d\n", s[i].name, s[i].age);
    }
    return 0;
}

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<string.h>//库函数strcmp头文件
//使用qsort排序结构体
struct Stu
{char name[20];int age;
};
//按照年龄排序
int cmp_stu_by_age(const void* e1,const void* e2)
{return ((struct Stu*)e1)->age - ((struct Stu*)e2)->age;//错误写法:return *((struct Stu*)e1)->age - *((struct Stu*)e2)->age;//错误原因:((struct Stu*)e1)->age,((struct Stu*)e2)->age 已经拿到结构体数组元素了,//            不需要再用解引用 * 通过地址去找它们。
}
//按照名字排序
int cmp_stu_by_name(const void* e1, const void* e2)
{return strcmp(((struct Stu*)e1)->name, ((struct Stu*)e2)->name);//库函数:strcmp//比较字符串大小
}
int main()
{struct Stu s[3] = { {"wanger",45},{"zhangsan",20},{"lisi",19} };int sz = sizeof(s) / sizeof(s[0]);qsort(s, sz, sizeof(s[0]), cmp_stu_by_age);int i = 0;for(i=0;i<sz;i++){printf("name: %s,age: %d\n", s[i].name, s[i].age);}printf("\n");qsort(s, sz, sizeof(s[0]), cmp_stu_by_name);for (i = 0; i < sz; i++){printf("name: %s,age: %d\n", s[i].name, s[i].age);}return 0;
}


思考:

为什么compare函数返回时用的是->,而main函数内打印时用的是.呢?

在C语言中, ->运算符和.运算符都是用于访问结构体成员的,但它们的使用场景不同。

->运算符用于通过指针访问结构体成员。在  compare  函数中,参数  a  和  b  是  const void* 类型的指针,
在函数内部将它们强制转换为  struct MyStruct* 类型的指针  s1  和  s2 ,所以使用->来访问结构体成员  num ,
如  s1->num 。

.运算符用于通过结构体变量直接访问结构体成员。在  main  函数中, arr  是结构体数组, 
arr[i]  是一个结构体变量,因此使用.来访问结构体成员  num  和  str ,如  arr[i].num  和  arr[i].str 。


http://www.ppmy.cn/embedded/173097.html

相关文章

SpringBoot3实战(从0快速搭建SpringBoot3工程、全局异常处理器、自定义封装结果类、自定义异常)(2025详细教程)(1)

目录 一、博客引言。 &#xff08;1&#xff09;SpringBoot3实战学习篇开篇介绍。 &#xff08;2&#xff09;Vue3实战学习篇回顾介绍。 二、从0快速搭建SpringBoot3工程。(详细步骤) &#xff08;1&#xff09;项目层次结构说明。 &#xff08;2&#xff09;SpringBoot3新工程…

【接口封装】——22、读写文件

解释&#xff1a; 1、封装内容&#xff1a;对不同文件内容的读取->处理->写入 2、文件流写入 3、插入处理函数&#xff1a; if (!replaceJsTxt(tmpFileContent)) return; 函数定义&#xff1a; #include <QMessageBox> #include <QTextStream>void init…

深度解读DeepSeek部署使用安全(48页PPT)(文末有下载方式)

深度解读DeepSeek&#xff1a;部署、使用与安全 详细资料请看本解读文章的最后内容。 引言 DeepSeek作为一款先进的人工智能模型&#xff0c;其部署、使用与安全性是用户最为关注的三大核心问题。本文将从本地化部署、使用方法与技巧、以及安全性三个方面&#xff0c;对Deep…

超精密工件小孔几何尺寸测量:自动化解决方案

下载链接&#xff1a;&#xff08;最新版本&#xff09;超精密工件小孔几何尺寸测量&#xff1a;自动化解决方案python脚本代码&#xff0c;可直接运行&#xff0c;内包含测试数据&#xff0c;亲测好用资源-CSDN文库 在现代制造业中&#xff0c;超精密工件的质量控制至关重要&a…

人工智能与人的智能,改变一生的思维模型【8】逆向思维

逆向偏差思维模型&#xff1a;顶尖高手如何「反常识」破局 &#xff08;斯坦福决策科学中心认证的逆向思考框架&#xff09; 一、直击本质&#xff1a;什么是逆向偏差思维&#xff1f; 定义&#xff1a; 逆向偏差思维是一种主动对抗本能认知倾向的决策模式&#xff0c;通过系…

Unity知识总结——算法

文章目录 1.常见排序算法1.冒泡排序2.选择排序3.插入排序4.快速排序5.归并排序6.希尔排序7.堆排序8.桶排序9.计数排序算法10.基数排序算法 2. 常见查找算法1.线性查找2.二分查找3.哈希查找4.二叉查找树5.平衡二叉查找树6.跳表7.Trie 树8.Bloom Filter 3.空间切割算法4.洗牌算法…

DeepSeek在医学领域的应用

DeepSeek作为高性能AI大模型&#xff0c;在医学领域的应用场景广泛&#xff0c;结合其在数据处理、自然语言理解和深度学习方面的优势&#xff0c;显著推动了医疗行业的智能化转型。以下是其核心应用场景及具体案例&#xff1a; 1. 辅助诊断与决策支持 临床辅助诊断&#xff1…

Node.js 的模块作用域和 module 对象详细介绍

目录 代码示例 1. 创建模块文件 module-demo.js 2. 导入模块并使用 module-demo.js 运行结果 总结 在 Node.js 中&#xff0c;每个文件都是一个独立的模块&#xff0c;具有自己的作用域。与浏览器 JavaScript 代码不同&#xff0c;Node.js 采用模块作用域&#xff0c;这意味…