指针进阶(三)

指针进阶(二)-CSDN博客https://blog.csdn.net/Xiaodao12345djs/article/details/142871406?spm=1001.2014.3001.5502

目录

五、函数指针

定义:

代码一:

代码二:

六、函数指针数组

定义:

用途:

七、指向函数指针数组的指针

八、回调函数

定义:

简易计算器(回调函数实现):

qsort函数快速排序

模拟实现qsort函数


五、函数指针

定义:

指向函数的指针

代码一:

cs 复制代码
(* (void (*)( ))0( )

代码二:

cs 复制代码
void (*siqnal)(int , void(*) (int))

六、函数指针数组

定义:

存放函数指针的数组

用途:

可以用来做建议计算器

cs 复制代码
int (*pf[5])(int, int) = { NULL,Add,Sub,Mul,Dir };

计算+、-、*、/

七、指向函数指针数组的指针

cs 复制代码
int (*(*pf)[5])(int,int)

八、回调函数

定义:

通过函数指针调用的函数

把函数指针指向的函数地址作为参数传递给另一个函数

简易计算器(回调函数实现):

cs 复制代码
#include <stdio.h>

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

void calc(int(*pf)(int, int))
{
	printf("请输入两个数:");
	int a = 0;
	int b = 0;
	scanf("%d %d", &a, &b);
	int ret = pf(a, b);
	printf("结果为%d\n", ret);
}

int main()
{
	calc(Add);
	calc(Sub);

	return 0;
}

qsort函数快速排序

cs 复制代码
#include <stdio.h>
#include <stdlib.h>

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

int cmp_int_name(const void* e1, const void* e2)
{
	return strcmp(((struct stu*)e1)->name, ((struct stu*)e2)->name);
}

int main()
{
	struct stu s1[3] = { {"wangling",20},{"caokai",19},{"zhanghua",30} };
	int sz = sizeof(s1) / sizeof(s1[0]);

	qsort(s1, sz, sizeof(s1[0]), cmp_int_name);

	int i = 0;
	for (i = 0; i < sz; i++)
	{
		printf("%s\n", s1[i]);
	}

	return 0;
}

模拟实现qsort函数

cs 复制代码
#include <stdio.h>

//用来交换
void swap(char* sp1, char* sp2, size_t width)
{
	int i = 0;
	for (i = 0; i < width; i++)
	{
		char tmp = *sp1;
		*sp1 = *sp2;
		*sp2 = tmp;
		sp1++;
		sp2++;
	}
}

//com_int用来比较e1和e2的大小
int com_int(const void* e1, const void* e2)
{
	return *(int*)e1 - *(int*)e2;
}

//模拟实现qsort
int my_qsort(void* base, size_t sz, size_t width, int(*cmp)(const void*, const void*))
{
	int i = 0;
	for (i = 0; i < sz - 1; i++)
	{
		int j = 0;
		for (j = 0; j < sz - 1 - i; j++)
		{
			if (cmp((char*)base + j * width, (char*)base + (j + 1) * width) > 0)
			{
				swap((char*)base + j * width, (char*)base + (j + 1) * width, width);
			}
		}
	}
}

int main()
{
	int arr[] = { 2,4,7,9,1,4,7,3,10,8,1,5 };
	int sz = sizeof(arr) / sizeof(arr[0]);

	my_qsort(arr, sz, sizeof(arr[0]), com_int);

	int i = 0;
	for (i = 0; i < sz; i++)
	{
		printf("%d ", arr[i]);
	}

	return 0;
}
相关推荐
木心月转码ing19 分钟前
Hot100-Day24-T128最长连续序列
算法
小肥柴27 分钟前
A2UI:面向 Agent 的声明式 UI 协议(三):相关概念和技术架构
算法
学高数就犯困3 小时前
性能优化:LRU缓存(清晰易懂带图解)
算法
CoovallyAIHub6 小时前
CVPR 2026 | MixerCSeg:仅2.05 GFLOPs刷新四大裂缝分割基准!解耦Mamba隐式注意力,CNN+Transformer+Mamba三
深度学习·算法·计算机视觉
CoovallyAIHub6 小时前
YOLO26-Pose 深度解读:端到端架构重新设计,姿态估计凭什么跨代领先?
深度学习·算法·计算机视觉
CoovallyAIHub7 小时前
化工厂气体泄漏怎么用AI检测?30张图3D重建气体泄漏场景——美国国家实验室NeRF新研究
深度学习·算法·计算机视觉
颜酱18 小时前
图的数据结构:从「多叉树」到存储与遍历
javascript·后端·算法
zone77391 天前
006:RAG 入门-面试官问你,RAG 为什么要切块?
后端·算法·面试
CoovallyAIHub1 天前
OpenClaw 近 2000 个 Skills,为什么没有一个好用的视觉检测工具?
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
CVPR 2026 | 用一句话告诉 AI 分割什么——MedCLIPSeg 让医学图像分割不再需要海量标注
深度学习·算法·计算机视觉