C语言 指针4

1、typedef 关键字

是用来重命名的,可以将复杂的类型简单化

typedef int* pint;

int main()

{

int* p1, p2;

pint p3, p4;

return 0;

}

2、函数指针数组

int(*pfArr4(int, int) = { add,sub,div });

3、转移表

函数指针的用途:转移表

4、回调函数

回调函数就是不是由函数的实现方式直接调用,而是在特定的条件发生时由另外的一方调用

举例

void print()

{

printf("hehe\n");

}

void test(void(*p)())

{

p();

}

int main()

{

test(print);

return 0;

}

5、qsort

在c语言中用来快速排序的函数,与冒泡排序相比,它可以排任意类型的数据

采用冒泡排序的算法思想用快速排序实现

这是冒泡排序

void bubble_sort(int arr\[\], int sz)

{

int i = 0;

for (i = 0; i < sz - 1; i++)

{

int flag = 1;

int j = 0;

for (j = 0; j < sz - 1 - i; j++)

{

if (arrj < arrj + 1)

{

int tmp = arrj;

arrj = arrj + 1;

arrj + 1 = tmp;

flag = 0;

}

}

if (flag == 1)

{

break;

}

}

}

用qsort来实现

void cmp_int(const void* p1, const void* p2)

{

if (*(int*)p1 > *(int*)p2)

return 1;

else if (*(int*)p1 < *(int*)p2)

return -1;

else

return 0;

}

void ptinr_arr(int arr\[\], int sz)

{

int i = 0;

for (i = 0; i < sz; i++)

{

printf("%d ", arri);

}

printf("\n");

}

int main()

{

int arr\[\] = { 2,1,4,6,5,3,8,7,9 };

int sz = sizeof(arr) / sizeof(arr0);

qsort(arr, sz, sizeof(arr0), cmp_int);

return 0;

}

使用冒泡排序,也能用来排序任意类型的数据

// 1. 比较函数:给 int 类型用,升序规则

int cmp_int(const void* p1, const void* p2)

{

// 把 void* 强转成 int* 再解引用,返回差值:>0 需交换,=0 相等,<0 不换

return *(int*)p1 - *(int*)p2;

}

// 2. 通用冒泡排序:能排任意类型数据

// base:数组首地址;sz:元素个数;width:每个元素字节大小;cmp:比较规则函数指针

void bubble_sort(void* base, size_t sz, size_t width, int (*cmp)(const void*, const void*))

{

// 3. 外层循环:控制排序趟数,sz 个元素排 sz-1 趟

for (size_t i = 0; i < sz - 1; i++)

{

int flag = 1; // 4. 优化标记:假设这一趟已经有序,不用再排

// 5. 内层循环:每一趟两两比较,每趟少比较 i 次(后面 i 个已排好)

for (size_t j = 0; j < sz - 1 - i; j++)

{

// 6. 计算第 j 个元素地址:char* 逐字节跳,j*width 跳到第 j 个元素

void* p1 = (char*)base + j * width;

// 7. 计算第 j+1 个元素地址

void* p2 = (char*)base + (j + 1) * width;

// 8. 调用比较函数:返回>0,说明 p1 比 p2 大,需要交换

if (cmp(p1, p2) > 0)

{

// 9. 定义和元素一样大的临时空间

char tempwidth;

// 10. 把 p1 复制到 temp

memcpy(temp, p1, width);

// 11. 把 p2 复制到 p1

memcpy(p1, p2, width);

// 12. 把 temp 复制到 p2,完成交换

memcpy(p2, temp, width);

flag = 0; // 13. 发生交换,说明这一趟没完全有序

}

}

if (flag == 1) // 14. 这一趟没交换,说明整体已有序,直接结束排序

{

break;

}

}

}

// 15. 打印 int 数组

void print_arr(int arr\[\], int sz)

{

for (int i = 0; i < sz; i++)

{

printf("%d ", arri);

}

printf("\n");

}

// 16. 测试函数

void test3()

{

int arr\[\] = { 3,1,5,4,9,8,0,6,7 }; // 待排序数组

int sz = sizeof(arr) / sizeof(arr0); // 计算元素个数

bubble_sort(arr, sz, sizeof(arr0), cmp_int); // 调用通用排序

print_arr(arr, sz); // 打印结果

}

int main()

{

test3(); // 运行测试

return 0;

}

相关推荐
To_OC10 小时前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode
鱼鱼不愚与14 小时前
《原来如此 | 第01期:为什么导航软件能预测红绿灯倒计时?》
算法
复杂网络19 小时前
论最小 Agent 计算机的形态
算法
kisshyshy1 天前
🍦 雪糕、食堂、火车厢:三幅漫画吃透栈、队列与链表
javascript·算法
猿人谷2 天前
不只是 CPU 阈值:STAR 如何用 GAT + Transformer 做容器级自动扩缩容?
人工智能·算法
复杂网络2 天前
Stable Diffusion 视觉大模型微调技术深度调研
算法
复杂网络2 天前
基于 Stable Diffusion 架构的视觉大模型代表性工作与原理深度解析
算法
MrZhao4002 天前
Agent Loop 如何用 Hook 扩展:权限、日志与工具拦截
算法
MrZhao4002 天前
Agent 为什么需要 Skills:别把所有知识都塞进 system prompt
算法