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

微网站定制wordpress cart插件

微网站定制,wordpress cart插件,全景校园网站开发,这几年做哪些网站能致富目录 1.C语言快速排序的库函数 1.使用qsort函数前先包含头文件 2.qsort的四个参数 3.qsort函数使用 对int类型的数据排序 运行结果 对char类型的数据排序 运行结果 对浮点型数据排序 运行结果 2.题外话:函数名的本质 1.C语言快速排序的库函数 cplusplus网的介绍 ht…目录 1.C语言快速排序的库函数 1.使用qsort函数前先包含头文件 2.qsort的四个参数 3.qsort函数使用 对int类型的数据排序 运行结果 对char类型的数据排序 运行结果 对浮点型数据排序 运行结果 2.题外话:函数名的本质 1.C语言快速排序的库函数 cplusplus网的介绍 https://legacy.cplusplus.com/reference/cstdlib/qsort/?kwqsort 解释: 1.使用qsort函数前先包含头文件stdlib.h 2.qsort的四个参数 base:指向要排序的数组(即数组名) num:数组元素的个数(类型size_t) size:每个元素所占的空间(类型size_t) compare:比较函数,用于比较数组的两个元素(这个参数有点特殊,之前没有见过:函数本身也可以作为另一个函数的参数) 函数没有返回值(void类型) 网站给出比较函数应该遵照的原型:int compar (const void* p1, const void* p2); 注意到比较函数的返回类型为int(显然有三种情况,负数,0和正数) 负数0正数*p1*p2*p1*p2 *p1*p2 网站给出比较函数的写法 int compareMyType (const void * a, const void * b) {if ( *(MyType*)a *(MyType*)b ) return -1;if ( *(MyType*)a *(MyType*)b ) return 0;if ( *(MyType*)a *(MyType*)b ) return 1; } 由于a是void*类型的,使用前应该强制类型转换为MyType类型,之后再解引用 3.qsort函数使用 对int类型的数据排序 #include stdlib.h int compare(const void* a, const void* b) {if (*(int*)a *(int*)b) return -1;if (*(int*)a *(int*)b) return 0;if (*(int*)a *(int*)b) return 1; }int main() {int arr[] { 3,5,1,6,2,3,9,0,8 };printf(排序前:);PrintArray(arr, sizeof(arr) / sizeof(arr[0]));qsort(arr, sizeof(arr) / sizeof(arr[0]), sizeof(int), compare);printf(排序后:);PrintArray(arr, sizeof(arr) / sizeof(arr[0]));return 0; } 备注:如果要排降序,compare函数有两种改法①将compare的返回值-1和1交换即可 ②或者将和交换 运行结果 对char类型的数据排序 #include stdio.h #include stdlib.h #include string.h int compare(const void* a, const void* b) {if (*(char*)a *(char*)b) return -1;if (*(char*)a *(char*)b) return 0;if (*(char*)a *(char*)b) return 1; }int main() {char arr[] { aoxhfekmc};printf(排序前:);printf(%s, arr);qsort(arr, sizeof(arr) / sizeof(arr[0])-1, sizeof(char), compare);printf(\n排序后:);printf(%s, arr);return 0; } 运行结果 对浮点型数据排序 #include stdio.h #include stdlib.h #include string.h int compare(const void* a, const void* b) {if (*(float*)a *(float*)b) return -1;if (*(float*)a *(float*)b) return 0;if (*(float*)a *(float*)b) return 1; }int main() {float arr[] { 3.1,5.4,7.9,10.31,6.66,1.1,0.9 };printf(排序前:);for (int i 0;i sizeof(arr) / sizeof(arr[0]); i)printf(%.2f , arr[i]);qsort(arr, sizeof(arr) / sizeof(arr[0]), sizeof(float), compare);printf(\n排序后:);for (int i 0; i sizeof(arr) / sizeof(arr[0]); i)printf(%.2f , arr[i]);return 0; } 运行结果 2.题外话:函数名的本质 在解释qsort函数的时候提到了函数本身也可以作为另一个函数的参数 测试以下代码,下断点至return 0;然后执行到断点处 #include stdio.h #include stdlib.h int compare(const void* a, const void* b) {if (*(float*)a *(float*)b) return -1;if (*(float*)a *(float*)b) return 0;if (*(float*)a *(float*)b) return 1; }int main() {printf(%p, compare);return 0; } 查看打印结果 在内存窗口中输入0x00C613FC后发现内存窗口直接跳到了0x00C61900;转到反汇编,查看compare函数的第一个指令的机器码和地址 因此函数名的本质是地址,其指向函数反汇编的第一条指令
http://www.hkea.cn/news/14452004/

相关文章:

  • 新人如何自学做网站dede游戏网站源码
  • 建设部 招投标网站网站建设推广公司价格
  • 网站商品台管理系统潍坊网站制作软件
  • 网站文字源码自己网站怎么做百度优化
  • 网络营销网站建设暗网做网站
  • 怎么屏蔽优酷网站的广告外包加工网会员
  • 外贸平台网站建设seo 网站结构调整
  • 南昌做网站的公司多不多html6
  • 鄂州市网站wordpress预约小程序
  • 西宁网站建设企业安徽海绵城市建设协会网站
  • 怎么用服务器搭建网站越众做的绿色建筑的网站
  • 外贸公司网站设计哪家好南京制作网架厂家
  • 公司的官方网站怎么做基于django的电子商务网站开发
  • 网站建设金思扬网络汽车制作公司排名
  • 建站程序的选择三五互联做网站怎么样
  • 济南做网站优化wordpress主题带中心
  • 合肥网站推广优化公司网站如何快速备案
  • 常德网站开发网站运营网站页码
  • wordpress网站好优化吗网站布局模板
  • 网站开发过程分为哪几个阶段四川省四川省住房和城乡建设厅网站
  • 在公司网站投简历该怎么做网址正能量
  • 休闲小零食网站开发方案建设网站的一般步骤
  • 网站开发的最后5个阶段如何在微信公众号里建设微网站
  • 网站设计 企业 济南百度关键词排名技术
  • 赤峰市网站建设外贸企业网站建设哪家好
  • 江苏越润建设有限公司网站校园网方案设计
  • 阿里云建站费用芜湖做网站哪家好
  • 云霄县建设局网站如何注册一个自己的公司
  • 网站开发教程流程xampp做网站设置
  • 深圳网站制作 公司官方网站怎样做