【c语言】了解指针,爱上指针(5)

了解指针,爱上指针(5)

  • 回调函数
  • qsort函数
  • 冒泡排序模拟实现qsort函数

回调函数

回调函数:就是一个通过函数指针调用的函数。
把函数的指针作为参数传给另一个函数,当这个指针被用来调用指向的函数时,此时被调用的函数就是回调函数。

前面我们讲到了转移表,在这把转移表的代码在回顾一遍:

void menu()
{
    printf("*************************************************\n");
    printf("*************************************************\n");
    printf("*******1.Add    2.Sub    3.Div      4.Mul********\n");
    printf("********************0.退出***********************\n");
    printf("*************************************************\n");
}

int Add(int x, int y)
{
    return x + y;
}

int Sub(int x, int y)
{
    return x - y;
}

int Div(int x, int y)
{
    return x / y;
}

int mul(int x, int y)
{
    return x * y;
}

int main()
{
    int input = 0;
    int x = 0;
    int y = 0;
    int ret = 0;
    int (*p[5])(int x, int y) = { 0,Add,Sub,Div,mul };
    do
    {
        printf("请选择:");
        scanf("%d",&input);
        if (input>=1&&input<=4)
        {
            printf("请输入两个操作数:");
            scanf("%d %d", &x, &y);

            ret = (*p[input])(x, y);
            printf("%d\n", ret);
        }
        else if (input == 0)
        {
            printf("退出计算器\n");
        }
        else
        {
            printf("请重新输入\n");
        }


    } while(input);
    return 0;
}

将转移表的代码加入回调函数:

void menu()
{
    printf("*************************************************\n");
    printf("*************************************************\n");
    printf("*******1.Add    2.Sub    3.Div      4.Mul********\n");
    printf("********************0.退出***********************\n");
    printf("*************************************************\n");
}

int Add(int x,int y)
{
    return x + y;
}

int Sub(int x,int y)
{
    return x - y;
}

int Div(int x,int y)
{
    return x / y;
}

int Mul(int x,int y)
{
    return x * y;
}

void Cals(int(*p)(int,int))
{
    int x=0;
    int y=0;
    printf("请输入两个参数:");
    scanf("%d %d",&x,&y);
    int ret = p(x,y);
    printf("%d\n",ret);
}



int main()
{
    int input = 0;
    do
    {
        menu();
        printf("请选择:");
        scanf("%d",&input);
        switch (input)
        {
            case 1:
                Cals(Add);
                break;
            case 2:
                Cals(Sub);
                break;
            case 3:
                Cals(Div);
                break;
            case 4:
                Cals(Mul);
                break;
            case 0:
                printf("退出\n");
                break;

        default:
            printf("请重新输入");
            break;
        }
    } while (input);
    return 0;
}

qsort函数

qsort函数声明

 void qsort(void *base, size_t nitems, size_t size, int (*compar)(const void *, const void*))
  • void*base,指向要排序的数组的第一个元素的指针。
  • size_t nitems 指向的数组的元素个数。
  • size_t size 指向的数组的大小。
  • int(compar)(const voidconst void) 用来比较两个数的函数。

这里我们用qsort函数来排序一个整型数组:

int com_int(const void* a, const void* b)
{
    return *(int*)a - *(int*)b;
}


int main()
{
    int a[10] = {2,1,4,3,6,8,9,3,1,10};
    int sz = sizeof(a) / sizeof(a[0]);
    qsort(a, sz, sizeof(a[0]), com_int);
    for (int i=0;i<10;i++)
    {
        printf("%d ",a[i]);
    }
    return 0;
}

在这里插入图片描述

用qsort函数排序一个字符数组:

char cmp_char(const void*a,const void*b)
{
    return *(char*)a - *(char*)b;
}
int main()
{
    char a[] = {'w','d','q','v','e'};
    int sz = sizeof(a) / sizeof(a[0]);
    qsort(a,sz,sizeof(a[0]),cmp_char );
    for (int i=0;i<sz;i++)
    {
        printf("%c ",a[i]);
    }
    return 0;
}

在这里插入图片描述
用qsort函数排序一个浮点型数组:
排序浮点型需要注意:不能想整型那样通过相减来判断大小,要用三目操作符。

int cmp_double(const void*a,const void*b)
{
    return *(double*)a > *(double*)b ? 1 : 0;
}
int main()
{
    double a[] = {1.2,3.1,4.2,9.6,3.1,5.5};
    int sz = sizeof(a) / sizeof(a[0]);
    qsort(a,sz,sizeof(a[0]),cmp_double );
    for (int i=0;i<sz;i++)
    {
        printf("%lf ",a[i]);
    }
    return 0;
}

在这里插入图片描述
用qsort函数排序一个字符串:

int cmp_char(const void*str,const void*str1)
{
    return strcmp(*(char**)str , *(char**)str1 );
}


int main()
{
    char* a[] = { "aaa" ,"fff","eee","bbb"};
    int sz = sizeof(a) / sizeof(a[0]);
    qsort(a,sz,sizeof(a[0]),cmp_char );
    for (int i=0;i<sz;i++)
    {
        printf("%s ", a[i]);
    }
    return 0;
}

在这里插入图片描述

冒泡排序模拟实现qsort函数

#include <stdio.h>
int int_cmp(const void* p1, const void* p2)
{
    return (*(int*)p1 - *(int*)p2);
}
void _swap(void* p1, void* p2, int size)
{
    int i = 0;
    for (i = 0; i < size; i++)
    {
        char tmp = *((char*)p1 + i);
        *((char*)p1 + i) = *((char*)p2 + i);
        *((char*)p2 + i) = tmp;
    }
}

void bubble(void* base, int count, int size, int(*cmp)(void*, void*))
{
    int i = 0;
    int j = 0;
    for (i = 0; i < count - 1; i++)
    {
        for (j = 0; j < count - i - 1; j++)
        {
            if (cmp((char*)base + j * size, (char*)base + (j + 1) * size) > 0)
            {
                _swap((char*)base + j * size, (char*)base + (j + 1) * size,
                    size);
            }
        }
    }
}

int main()
{
    int arr[] = { 1, 3, 5, 7, 9, 2, 4, 6, 8, 0 };
    int i = 0;
    bubble(arr, sizeof(arr) / sizeof(arr[0]), sizeof(int), int_cmp);
    for (i = 0; i < sizeof(arr) / sizeof(arr[0]); i++)
    {
        printf("%d ", arr[i]);
    }
    printf("\n");
    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/643438.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Vue CLI 的服务介绍与使用(2024-05-20)

1、介绍 Vue CLI 是一个基于 Vue.js 进行快速开发的完整系统&#xff0c;提供&#xff1a; 通过 vue/cli 实现的交互式的项目脚手架。 通过 vue/cli vue/cli-service-global 实现的零配置原型开发。 一个运行时依赖 (vue/cli-service)&#xff0c;该依赖&#xff1a; 可升级…

【论文阅读】使用深度学习及格子玻尔兹曼模拟对SEM图像表征粘土结构及其对储层的影响

文章目录 0、论文基本信息1、深度学习2、可运行程序—Matlab3、深度切片3、LBM模拟4、局限性 0、论文基本信息 论文标题&#xff1a;Characterizing clay textures and their impact on the reservoir using deep learning and Lattice-Boltzmann simulation applied to SEM i…

EI稳定检索--人文社科类会议(ICBAR 2024)

【ACM独立出版】第四届大数据、人工智能与风险管理国际学术会议 (ICBAR 2024) 2024 4th International Conference on Big Data, Artificial Intelligence and Risk Management 【高录用•快检索&#xff0c;ACM独立出版-稳定快速EI检索 | 往届均已完成EI, Scopus检索】 【见…

[less配置]vue2引入less

1、终端输入&#xff1a;npm install less less-loader --save-dev 2、在package.json查看是否安装less依赖 3、调用

【前端笔记】记录一个能优化Echarts Geo JSON大小的网站

前端在使用Echarts等可视化图表库会不可避免遇到的问题&#xff0c;渲染地图的数据太大。 而有那么一个网站能给予这个问题一个解决方案&#xff1a;链接在此 使用方法很简单&#xff0c;首先先进入网站&#xff0c;如果进入了会是这个页面&#xff1a; 接着&#xff0c;选择一…

[SCTF2019]babyre

打开看看还是有花指令 解除后首先pass1是解maze&#xff0c;好像又是三维的 x是25&#xff0c;也就是向下跳五层,注意是立体的 得到 passwd1&#xff1a; ddwwxxssxaxwwaasasyywwdd 接着往下看 有一个加密函数IDA逆向常用宏定义_lodword-CSDN博客 unsigned __int64 __fastca…

【文献阅读】ESG评级分化和企业绿色创新

ESG评级分化和企业绿色创新 摘要 &#xff08;1&#xff09;本研究通过实证探讨了ESG评级差异是否以及如何影响企业绿色创新。以中国上市公司为样本&#xff0c;我们发现ESG评级差异对企业绿色创新有积极的影响 。经过几次稳健性检查后&#xff0c;该结果仍然成立。 &#xff…

【CTF Web】CTFShow web4 Writeup(SQL注入+PHP+字符型注入)

web4 1 管理员阿呆又失败了&#xff0c;这次一定要堵住漏洞 解法 注意到&#xff1a; <!-- flag in id 1000 -->拦截很多种字符&#xff0c;连 select 也不给用了。 if(preg_match("/or|\-|\\\|\/|\\*|\<|\>|\!|x|hex|\(|\)|\|select/i",$id)){die(&q…

图计算与ID-Mapping

目录 一、图计算&#xff1a; 图计算起源&#xff1a; 图计算特点&#xff1a; 图计算的应用&#xff1a; Spark GraphX图处理库 ID-Mapping 二、总结&#xff1a; 一、图计算&#xff1a; 图&#xff08;Graph&#xff09;是用于表示对象之间关联关系的一种抽象数据结构…

著名书法家王杰宝做客央视频《笔墨写人生》艺坛人物经典访谈节目

印象网北京讯&#xff08;张春兄、冯爱云&#xff09;展示艺术风采&#xff0c;构建时代精神。5月25日&#xff0c;著名书法家、羲之文化传承人王杰宝&#xff0c;做客央视频《笔墨写人生》艺坛人物经典访谈节目&#xff0c;与中央电视台纪录频道主持人姚文倩一起&#xff0c;分…

JVM-调优之-如何使用arthas-观察jvm-cpu-内存-垃圾回收等信息

前言&#xff1a; 可以简单代替把dump文件下载下来后用visualvm分析了&#xff1b;跟visualvm类似的&#xff1b; docker中如何安装arthas看这个&#xff1a;docker中怎么使用arthas_arthas 集成到容器镜像-CSDN博客 curl -O https://arthas.aliyun.com/arthas-boot.jar wget …

网络命令

1.write 路径&#xff1a;/usr/bin/write 权限&#xff1a;所有用户 语法&#xff1a;write <用户名> 功能&#xff1a;给用户发信息&#xff0c;以CtrlD保存结束 例&#xff1a;#write 04110606 注&#xff1a;输错了的时候&#xff0c;ctrl退格键或是delete 接收…

一款即支持3v3单片机又支持5v单片机的485收发芯片

原理图参考 H7-TOOL 特此记录 anlog 2024年5月21日

嵌入式之音频基础知识

声音特性 1、响度&#xff1a;人主观上感觉声音的大小&#xff08;俗称音量&#xff09;&#xff0c;由“振幅”和人离声源的距离决定&#xff0c;振幅越大响度越大&#xff0c;人和声源的距离越小&#xff0c;响度越大&#xff1b; 2、音调&#xff1a;声音的高低&#xff0…

逍遥模拟器安装xp时报错处理

在执行script.sh&#xff0c;无法执行程序&#xff0c;报错如下&#xff1a; Mounting /system and /vendor read-write /dev/block/sda6 is read-only 尝试了很多种的方法&#xff0c;都不行 经过研究发现是逍遥模拟器的设置问题&#xff1a; 出问题时&#xff0c;磁盘共享…

【重制版】Unity Meta Quest 一体机开发(一):前期准备,Meta XR SDK导入和环境配置,配置玩家物体

文章目录 &#x1f4d5;教程说明&#x1f4d5;Meta XR SDK 介绍&#x1f4d5;前期准备⭐开启开发者模式⚡在 Meta 官网申请开发者⚡在 Meta Quest 手机 APP 开启开发者 ⭐电脑需要下载的软件⚡Meta Quest Link&#xff08;以前叫做Oculus PC客户端&#xff09;⚡Oculus ADB Dri…

【iOS】——工厂设计模式

文章目录 一、设计模式创建型模式结构型模式行为型模式 二、设计模式七大准则三、简单工厂模式四、工厂方法模式五、抽象工厂模式 一、设计模式 设计模式是指在特定上下文中解决常见问题时所采用的一套可复用的解决方案。这些模式是面向对象编程中的通用概念&#xff0c;广泛应…

点云处理中阶 Octree模块

一、什么是Octree 八叉树&#xff08;Octree&#xff09;是一种用于描述三维空间的树状数据结构。八叉树的每个节点表示一个正方体的体积元素&#xff0c;每个节点有八个子节点&#xff0c;这八个子节点所表示的体积元素加在一起就等于父节点的体积。一般中心点作为节点的分叉中…

《计算机网络微课堂》2-3 传输方式

本节课我们介绍几种传输方式&#xff1a; 串行传输和并行传输同步传输和异步传输单工&#xff0c;半双工‍‍以及全双工通信 ​​ ‍ 串行 我们首先来看串行传输和并行传输&#xff0c;串行传输是指‍‍数据是一个比特依次发送的&#xff0c;因此在发送端和接收端之间‍‍只…

每日5题Day10 - LeetCode 46 - 50

每一步向前都是向自己的梦想更近一步&#xff0c;坚持不懈&#xff0c;勇往直前&#xff01; 第一题&#xff1a;46. 全排列 - 力扣&#xff08;LeetCode&#xff09; class Solution {//这道题就是一个dfs//把所有结果遍历&#xff0c;到叶子节点就可以添加结果了List<Int…