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

湘潭网站建设 h磐石网络时尚类网站建设

湘潭网站建设 h磐石网络,时尚类网站建设,免费手游平台app,企业网银app下载qsort函数介绍具体作用qsort函数是一种用于对不同类型数据进行快速排序的函数#xff0c;排序算法有很多最常用的冒泡排序法仅仅只能对整形进行排序,qsort不同,排序类型不受限制,qsort函数的底层原理是一种快速排序.基本构造qsort( void* arr, int sz, int sizeof, cmp_code);…qsort函数介绍具体作用qsort函数是一种用于对不同类型数据进行快速排序的函数排序算法有很多最常用的冒泡排序法仅仅只能对整形进行排序,qsort不同,排序类型不受限制,qsort函数的底层原理是一种快速排序.基本构造qsort( void* arr, int sz, int sizeof, cmp_code);void* arr:任意类型数组的第一个首元素int sz:数组的总元素个数int sizeof:该数组类型字节数cmp_code:用于交换的函数,其函数需要用户自行定义,标准为int cmp_code(const void * p1,const void * p2)形参1为要交换的元素,形参2为要交换的元素的后一个元素当返回值大于0则表示p1p2当返回值小于0则表示p1p2当返回值等于0则表示p1p23.使用方法//qsort使用练习 //对整形进行排序 int My_code(const void* p1, const void* p2) {return *((int*)p1) - *((int*)p2); } int main() {int arr[5] { 2,1,4,6,3 };int sz sizeof(arr) / sizeof(arr[0]);qsort(arr,sz,sizeof(arr[0]),My_code);int i 0;for (i 0; i sz; i){printf(%d , arr[i]);}return 0; }//对字符型排序 int My_code(const void* p1, const void* p2) {return strcmp((char *)p1,(char *) p2); } int main() {char arr[] badcf;int sz strlen(arr);qsort(arr, sz, sizeof(arr[0]), My_code);puts(arr);return 0; }//对结构体排序 //对年龄进行排序升序 struct Stu {int age;char name[20];}; int My_code(const void* p1, const void* p2) {return ((struct Stu*)p1)-age - ((struct Stu*)p2)-age; } int main() {struct Stu p[] { {20,zhangsan},{19,lisi},{21,wangwu}};int sz sizeof(p) / sizeof(p[0]);qsort(p, sz, sizeof(p[0]), My_code);int i 0;for (i 0; i sz; i){printf(%d , (pi)-age);}return 0; }//对名字进行排序升序 struct Stu {int age;char name[20];}; int My_code(const void* p1, const void* p2) {return strcmp(((struct Stu*)p1)-name, ((struct Stu*)p2)-name); } int main() {struct Stu p[] { {20,zhangsan},{19,lisi},{21,wangwu} };int sz sizeof(p) / sizeof(p[0]);qsort(p, sz, sizeof(p[0]), My_code);int i 0;for (i 0; i sz; i){printf(%s , (p i)-name);}return 0; }4.使用qsort模拟实现冒泡排序算法//我们先实现一个冒泡排序 void Code_one(int* arr, int sz) {//冒泡排序为两两比较,因此进行一轮比较得出一个元素//一轮需比较sz-1-得出的元素次,总共需要sz-1轮int i 0;int j 0;for (i 0; i sz - 1; i){for (j 0; j sz - 1 - i; j){int tmp 0;//两两比较进行交换if (arr[j] arr[j 1]){tmp arr[j];arr[j] arr[j 1];arr[j 1] tmp;}}}for (i 0; i sz; i){printf(%d , arr[i]);} } int main() {//定义整形数组//排升序int arr[] { 2,3,1,5,6,8,9 };//计算元素个数int sz sizeof(arr) / sizeof(arr[0]);//分装一个函数实现冒泡排序Code_one(arr, sz);return 0; }//qsort模拟实现冒泡排序可排任意类型 int cmp(const void* p1,const void* p2) {return (*(int*)p1) - (*(int*)p2); } void Smin(const void* p1,const void* p2, int cont) {int i 0;char tmp 0;//利用循环,我们将要交换的元素内存依次交换//因为是强转为char类型,我们也有字节大小,我们只需将每一个字节交换即可for (i 0; i cont; i){tmp *((char*)p1 i);*((char*)p1i) *((char*)p2 i);*((char*)p2 i) tmp;} } void Sqort_code(void* arr, int sz, int cont, int (*m)(const void*,const void*)) {int i 0;int j 0;//总趟数for (i 0; i sz - 1; i){//一趟冒泡排序for (j 0; j sz - 1 - i; j){//在冒泡排序中,判断条件为arr[j]arr[j1]//而现在我们想排任意类型的数据时,我们可以调用m函数,//利用qsort性质,大于返回0,小于返回0等于返回0//而m函数参数我们可以强制转换为char*类型j*cont(类型字节数)//因为char类型为1字节,char指针(j*cont(类型字节数))也就等于//任意类型指针j的表示方法,这种表示方法利于我们排列不同的类型if (m((char*)arr j * cont, (char*)arr (j 1) * cont)0){//交换分装Smin函数用于交换形参将要交换的元素地址和元素类型字节传过去Smin((char*)arr j * cont, (char*)arr (j 1)* cont, cont);}}} } int main() {//假设要将整形数组排成升序int arr[] { 2,3,1,4,7,6,9,8 };//分装一个函数模拟实现qsortSqort_code(arr, sizeof(arr) / sizeof(arr[0]), sizeof(int), cmp);int i 0;for (i 0; i sizeof(arr) / sizeof(arr[0]); i){printf(%d , arr[i]);}return 0; }
http://www.hkea.cn/news/14465101/

相关文章:

  • 建设系统网站全名天津做网站哪家好
  • 运维负责做网站吗iis6 静态网站
  • 深圳市年年卡网络科技公司是什么网站建设和谷歌优化
  • 报考大专网站肇庆wordpress图片更换
  • 柳州论坛网站建设肇庆企业网站建设
  • 长春做企业网站温州做网站老师
  • 查询公司的网站备案开发工具指的是什么
  • 枣庄专业三合一网站开发哪里可以检测短链脂肪酸
  • 建设企业网站官网下载中心为什么要做手机网站
  • 东城网站开发找回微信
  • 品牌网站建设专家网站开发招聘需要
  • 黄冈网站推广软件下载网站建设公司哪家强
  • 网站开发有前途么有模板了怎么建设网站
  • 临沂市建设局网站改版dw用ps切片做网站
  • 常州网站建设外包公司哪家好vivo应用商店下载安装
  • 网站开发的基础网站空间在哪申请
  • 发帖百度秒收录网站分享企业管理培训课程机构排名
  • 以下不属于网站建设优化wordpress文件上传失败
  • 深圳建设工程协会网站平台一直维护是不是要跑路了
  • 夜间正能量网站商丘网红宋飞
  • 网络建设与网站建设微商怎么做自己的网站
  • 网站建设 天佑互联建设一个旅游网站的目的是什么
  • 网站案例模板百度推广登录入口下载
  • 网站注册商是什么wordpress知识
  • 网站开发是什么部门中装建设002822股吧
  • 网站建设需要数学网页设计网站的主题
  • 企业申请网站建设请示计算机编程是做网站
  • 深圳网站建设制作视频软件网页制作教程案例
  • 建设招标网是什么网站推广员网站
  • 网站做数据分析软件工程与项目管理