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

淘宝优惠劵网站怎么做wordpress getposts

淘宝优惠劵网站怎么做,wordpress getposts,wordpress详细教程,晋州外贸网站建设当你为错过太阳而哭泣的时候,你也要再错过群星了。 --泰戈尔 目录 一.qsort快速排序的实现 二.模拟实现一个qsort功能的函数 一.qsort快速排序的实现 下面是 qsort() 函数的声明: void qsort(void *base, size_t nitems, size_t size, int (…

当你为错过太阳而哭泣的时候,你也要再错过群星了。          --泰戈尔

 

目录

一.qsort快速排序的实现

二.模拟实现一个qsort功能的函数


一.qsort快速排序的实现

下面是 qsort() 函数的声明

void qsort(void *base, size_t nitems, size_t size, int (*compare)(const void *p1, const void* p2))

注意p1和p2是待比较两个数的地址,你不能直接写成*p1和*p2来找到这两个数,因为p1和p2都是void*的指针,无类型的指针。void*可以接收任何类型的指针,所以使用*p1和*p2时,你必须强制类型转换为你需要的类型。

参数: 

  • base -- 指向要排序的数组的第一个元素的指针。
  • nitems -- 由 base 指向的数组中元素的个数。
  • size -- 数组中每个元素的大小,以字节为单位。
  • compare -- 用来比较两个元素的函数,其实就是一个函数指针。

对一个数组里面的数字进行升序排序,可以使用冒泡排序(之前写的) ,但是冒泡排序效率比较低,而且只能对数字进行排序,但是qsort函数可以实现各种各样的排序

我们就先来使用qsort来对数组的数字进行升序排序。

#include<stdio.h>
#include<stdlib.h>//qsort所需要的头文件
int cmp_int(const void* p1, const void* p2)
//cmp_int这个函数是我们使用者提供的,你可以随便写成什么名字
{return (*(int*)p1 - *(int*)p2);//(int*)强制类型转换为整型指针,再解引用找到元素
}
void print(int arr[], int sz)
{int i = 0;for (i = 0; i < sz; i++){printf("%d ", arr[i]);}
}
int main()
{int arr[10] = { 5,3,7,8,9,1,2,0,4,6 };//void qsort(void* base, size_t nitems, size_t size, int (*compare)(const void* p1, const void* p2))int sz = sizeof(arr) / sizeof(arr[0]);//求的数组的大小,对应的就是nitems//这里的arr对应base//sizeof(arr[0])对应的就是size,数组每个元素的字节大小qsort(arr, sz, sizeof(arr[0]), cmp_int);print(arr, sz);return 0;
}

我们再来使用qsort来实现复杂一点点的结构体名字排序,你就会感到qsort的神奇之处。

我们对一个字符串进行比较,自然要用到strcmp函数。

strcmp函数:用于比较两个字符串的ASCll值并根据比较结果返回整数。基本形式为strcmp(str1,str2),若str1=str2,则返回零;若str1<str2,则返回负数;若str1>str2,则返回正数,strcmp函数是对字符串一个一个字符进行比较,如果第一个字符串的第一个字符已经大于第二个字符串的第一个字符了,strcmp就直接返回0了,就不用继续比较下面的字符串了。

比如:abcdffbb字符串进行比较,因为a的ASCll值已经小于f的ASCll值了,所以返回小于0。比较结束。

#include<stdio.h>
#include<stdlib.h>
struct stu
{int age;char name[20];
};
int cmp_name(const void* p1, const void* p2)
{return strcmp(((struct stu*)p1)->name, ((struct stu*)p2)->name);//指针访问结构体变量使用->
}
void print(struct stu S[], int sz)
{int i = 0;for (i = 0; i < sz; i++){printf("%s\n", S[i].name);}
}
int main()
{struct stu S[] = { {20,"chen kang"},{19,"wang ti"},{21,"di shu"} };//创建一个结构体数组int sz = sizeof(S) / sizeof(S[0]);qsort(S, sz, sizeof(S[0]), cmp_name);print(S, sz);return 0;
}

上面我们使用qsort函数来排序数组和结构体中的字符串,可以看出qsort不用像冒泡排序那样确定趟数,而是qsort自己继续往后面排序。

总结qsort函数优点:

1.不需要确定趟数。

2.可以对各种类型进行排序。

二.模拟实现一个qsort功能的函数

接下来我们就要来写一个模拟qsort函数功能的函数,来理解qsort函数到底是如何进行排序的

#include<stdio.h>
void Swap(char* p1, char* p2, int width)
{int i = 0;for (i = 0; i < width; i++){	//width就是一个数的字节大小char temp = 0;temp = *p1;*p1 = *p2;*p2 = temp;p1++;p2++;//通过一个一个的字节交换,从而将一个数交换}
}
void sml_qsort(void* base, size_t num, size_t width, int(*cmp)(const void* p1, const void* p2))
{//size_t表=表示无符号整型,这里也可以写成intint i = 0;int j = 0;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){//(char*)base + j * width就是一个数的全部字节大小,无论是排序什么类型,都可以这样使用//这里调用cmp指针从而调用cmp_int函数,而cmp_int就是比较两个数的大小//cmp就是一个回调函数Swap((char*)base + j * width, (char*)base + (j + 1) * width,width);}}}
}
int cmp_int(const void* p1, const void* p2)
{return *(int*)p1 - *(int*)p2;
}
void print(int arr[], int sz)
{int i = 0;for (i = 0; i < sz; i++){printf("%d ", arr[i]);}
}
int main()
{int arr[10] = { 1,4,7,3,2,5,8,0,9,6 };int sz = sizeof(arr) / sizeof(arr[0]);sml_qsort(arr, sz, sizeof(arr[0]),cmp_int);//sml是simulation单词的缩写,也就是模拟的意思print(arr, sz);return 0;
}

我们还可以用sml_sqort函数来排序结构体等等,只需要修改一点点代码就可以实现。这里大家就可以自己动手尝试。 

希望大家给老弟赞赞,谢谢!

http://www.yayakq.cn/news/193853/

相关文章:

  • 上的网站app长春做网站优化价格
  • 个人购物网站需要备案吗中国全案设计联盟
  • 宁波静态网站建设购物商城建设网站
  • 手机在线制作网站天津哪里可以做网站
  • 网上书店网站建设方案策划wordpress批量提交表单
  • 网站建设 翻译wordpress插件去除google
  • dedecms 生成网站地图做模板网站的利与弊
  • 当当网电子商务网站建设特点网站建设的商业计划书
  • 济宁网站建设 帮站制作单页网站要网址
  • 网站显示iis7wordpress没有加载图片
  • 网站建设288wordpress googlevis 嵌入
  • 创新网站建设工作专题网站开发工具有哪些
  • 微信手机网站支付怎么做网站被降权怎么办
  • 国外的做的比较优秀的网站有哪些网页制作自学教程
  • 北京网站制作公司报价网站建设关键技术
  • 如何新建一个网站.net开发的网站 能做成app吗
  • 网站源码陕西省信用建设门户网站
  • 尚海整装电话号码湛江seo
  • 专业的建站公司都具备什么条件网站开发集成工具
  • 做软件开发的网站有哪些阿里云快速备份网站
  • 商场网站模板aspcms网站无法打开
  • 升级的网站显示什么律师微网站制作
  • 更改网站备案负责人深圳市房地产信息网官网
  • 做网站怎么选择上市公司深广纵横设计公司官网
  • 使用jquery的网站展馆设计论文
  • 濮阳网站建设陈帅小程序搜索排名
  • 大连优化网站课程wordpress主题如何
  • 全国好的深圳网站设计新华网
  • 温州网页模板建站外包网络优化
  • 淮南二中网站建设wordpress市场