当前位置: 首页 > news >正文

网站建设年费企业门户网站建设机构

网站建设年费,企业门户网站建设机构,网站索引量是什么,重庆造价工程建设信息网站目录 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
http://www.dnsts.com.cn/news/253453.html

相关文章:

  • 开发网站app公司wordpress如何安装主题
  • 洛阳建设局网站护肤品网站建设分析
  • 北京网站优化流程塘厦镇住房规划建设局网站
  • 创建网站如何注册如何规划企业网站
  • 苏州企业建站公司手机app定制开发公司
  • 昆明做烤瓷牙哪去柏德L网站利用博客做网站排名
  • 网站建设美工百度百科进度跟踪网站开发
  • 网站建设如何把代码seo搜狗
  • 浙江做网站公司要服务网站建设
  • 企业网站模板建立流程建筑材料网
  • 教做发绳的网站广告门
  • 网站开发培训训沈阳做网站费用
  • 仿淘宝网站建设做一家视频网站吗
  • 如何推广网站网站推广常用方法wordpress vip查看插件
  • 建设合同网上备案上哪个网站郴州网吧
  • 网站建设实例分析wordpress背景代码
  • 淘宝网站建设合同网站建设情况通报
  • 定制建站北京公司注册虚拟地址
  • 个人网站做哪种类型青海西宁网站建设
  • h5做网站用什么框架网站模版库
  • 网站建站前期准备工作公司logo查询网站
  • 西宁设计网站手机端网站开发素材
  • 网站地址是什么百度主机做视频网站怎么样
  • 本地网站模版批量修改网站字符上海排名seo公司
  • 网站制作 推荐新鸿儒教你做网站的视频
  • 医院双语网站建设的意义仿360电影网站源码
  • 阿里云快速做网站wordpress制作友情链接
  • 弹窗网站制作大数据分析培训机构
  • 苏州网站建设n苏州网站建设公司湖南株洲网站建设
  • 景安 怎么把网站做别名怀化组织部网站