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;

}

相关推荐
wabs66612 分钟前
关于贪心算法【划分字母区间】的问题总结(C++语法)
算法·贪心算法
啦啦啦啦啦zzzz42 分钟前
数据结构:二叉树的线索化
数据结构·算法
2401_872418781 小时前
算法入门:并查集(Disjoint Set / Union-Find):连通性问题的利器
算法
luj_17681 小时前
R语言生态优势与学习曲线分析
c语言·开发语言·网络·经验分享·算法
计算机安禾1 小时前
【算法分析与设计】第36篇:计算几何基础:凸包问题的分治与扫描线解法
大数据·人工智能·算法·机器学习·剪枝
叶子野格1 小时前
《C语言学习:文件操作》16
c语言·开发语言·c++·学习·visual studio
货拉拉技术1 小时前
飞速发展的计算机视觉
人工智能·算法
AI科技星1 小时前
万有引力G与真空介电常数ε0全维度完整关系式汇编(基于v=c螺旋时空理论)
c语言·开发语言·前端·javascript·网络·汇编·electron
如竟没有火炬2 小时前
寻找峰值——二分
java·开发语言·数据结构·python·算法·散列表
C^h2 小时前
6轴达妙机械臂
c语言