网站建设年费,企业门户网站建设机构,网站索引量是什么,重庆造价工程建设信息网站目录
1.回调函数
2.qsort函数
//整形数组排序
//结构体排序
3.模拟实现qsort
//整型数组排序
//结构体排序 1.回调函数 回调函数就是一个通过函数指针调用的函数。如果你把函数的指针#xff08;地址#xff09;作为参数传递给另一个函数#xff0c;当这个指针被用来…目录
1.回调函数
2.qsort函数
//整形数组排序
//结构体排序
3.模拟实现qsort
//整型数组排序
//结构体排序 1.回调函数 回调函数就是一个通过函数指针调用的函数。如果你把函数的指针地址作为参数传递给另一个函数当这个指针被用来调用其所指向的函数时我们就说这是回调函数。回调函数不是由该函数的实现方直接调用而是在特定的事件或条件发生时由另外的一方调用的用于对该事件或条件进行响应。 即用函数指针调用函数 还是用计算器来举例
#define _CRT_SECURE_NO_WARNINGS
#includestdio.h
int Add(int x, int y)
{return x y;
}int Sub(int x, int y)
{return x - y;
}int Mul(int x, int y)
{return x * y;
}int Div(int x, int y)
{return x / y;
}
void calc(int (*pf)(int, int))//pf是函数指针指向上面四个函数中的一个
{int x, y;printf(请输入两个操作数);scanf(%d%d, x, y);printf(%d\n, pf(x, y));
}
void menu()
{printf(********** Ji Suan Qi **********\n);printf(********************************\n);printf(******* 1.add 2.sub *******\n);printf(******* 3.mul 4.div *******\n);printf(******* 0.exit *******\n);printf(********************************\n);
}
int main()
{int input 0;do{menu();printf(请选择);scanf(%d, input);switch (input){case 1:calc(Add);break;case 2:calc(Sub);break;case 3:calc(Mul);break;case 4:calc(Div);break;case 0:printf(退出计算器\n);break;default:printf(输入错误请重新输入\n);break;}} while (input);return 0;
}此时被调用的AddSubMulDiv函数就是回调函数。
2.qsort函数
头文件#includestdlib.h底层用的是快速排序快排格式如下 base待排序数组的起始位置num待排序数组元素个数width每个元素所占用的字节大小compare一个比较函数指两个参数均为const void*目的是使其可以接受任何类型的参数返回类型为int。 //整形数组排序
冒泡排序失业了哈哈哈~
#define _CRT_SECURE_NO_WARNINGS
#includestdio.h
#includestdlib.h
int cmp_int(const void* e1, const void* e2)
{return *(int*)e1 - *(int*)e2;//将无类型的e1e2强制转换为int*类型
}
int main()
{int arr[] { 9,8,7,6,5,4,3,2,1,0 };int sz sizeof(arr) / sizeof(arr[0]);qsort(arr, sz, sizeof(0), cmp_int);for (int i 0; i sz; i){printf(%d , arr[i]);}return 0;
}//结构体排序
#define _CRT_SECURE_NO_WARNINGS
#includestdio.h
#includestdlib.h
#includestring.hstruct Stu
{char name[20];int age;
};//根据年龄排序
int cmp_age(const void* e1, const void* e2)
{return ((struct Stu*)e1)-age - ((struct Stu*)e2)-age;
}//根据姓名排序
int cmp_name(const void* e1, const void* e2)
{return strcmp(((struct Stu*)e1)-name , ((struct Stu*)e2)-name);
}int main()
{struct Stu s[3] { {zhangsan,20},{lisi,18},{wangwu,22} };int sz sizeof(s) / sizeof(s[0]);qsort(s, sz, sizeof(s[0]), cmp_age);qsort(s, sz, sizeof(s[0]), cmp_name);return 0;
} 3.模拟实现qsort
在冒泡排序的基础上改造使其可以排序任意不只整型数组指定的数组。
//整型数组排序
#define _CRT_SECURE_NO_WARNINGS
#includestdio.h
#includestdlib.h//比较
int cmp_int(const void* e1, const void* e2)
{return *(int*)e1 - *(int*)e2;
}//交换——一个字节一个字节的换
void Swap(char* buf1, char* buf2, int width)
{int i 0;for (i 0; i width; i){char tmp *buf1;*buf1 *buf2;*buf2 tmp;buf1;buf2;}
}//冒泡排序改造
void bubble_sort(void* base, size_t num, size_t width, int(*cmp)(const void* e1, const void* e2))
{size_t i, j;for (i 0; i num - 1; i){for (j 0; j num - 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[] { 9,8,7,6,5,4,3,2,1,0 };int sz sizeof(arr) / sizeof(arr[0]);bubble_sort(arr, sz, sizeof(arr[0]), cmp_int);//模拟qsortfor (int i 0; i sz; i){printf(%d , arr[i]);}return 0;
}
//结构体排序
以之前 qsort 排序结构体为例函数主体不变只需将cmp_int 换为cmp_name或cmp_age即可这里就不赘叙了。 G了G了有点小难啊哭泣.jpg