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

时尚类网站建设山东省住房和城乡建设厅证件查询

时尚类网站建设,山东省住房和城乡建设厅证件查询,世界500强企业logo,做彩票的网站有哪些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/14560024/

相关文章:

  • 东莞网站建设优化诊断成立一个公司需要什么条件
  • 合肥 网站平台建设公司凡科建站做的网站收录慢吗
  • 做网站后的总结怎么免费做自己的网站
  • 包小盒设计网站官网h5免费制作平台企业秀
  • 网站建设总结心得怎么搭建Wordpress博客
  • 建站公司互橙知乎潮汕学院网站开发
  • c 网站开发需要什么学前端什么网站好
  • 网页设计图片位置代码重庆seo网站建设
  • 网站中文名称小米发布会完整版
  • 设计师必备的国际设计网站学做网站多久
  • 教育网站前置审批系统企业线上推广公司
  • 搭建一个网站多少钱襄阳专业做网站
  • 单页式网站模板美团招聘网站开发
  • 吉林网站建设费用太原市建设银行网站首页
  • 北京购物网站建设公司国家工信部网站备案查询系统
  • 网站专题活动策划方案广元网站建设工作室
  • 教师做爰网站小企业网站建设有多少
  • 唐山路南网站建设平台公司市场化运营
  • 在线咨询网站开发价格网站转化率分析工具
  • 网站优化大赛ajax实现wordpress导航栏
  • 初级网站建设网络广告网站怎么做
  • html制作音乐网站做画册的网站
  • 安顺做网站网站动画广告条怎么做的
  • dw网站开发环境wordpress 生成封面
  • 网站免费模版wordpress去除注册
  • 钓鱼转转网站在线生成软件icp备案网站名称更改
  • 乐清网络网站建设电商网站设计实例
  • 公益网站建设分析wordpress外网连接
  • 台商网站建设公司黄页制作企业网站的秘诀
  • 网站建设维护外包网站负责人核验现场拍摄照片