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

宁城县建设局网站淘宝网站怎么做的

宁城县建设局网站,淘宝网站怎么做的,茂名市城乡和住房建设局网站,工程公司取名字参考大全我们今天来讲讲八大排序中的快速排序#xff0c;快速排序最明显的特点就是排序快#xff0c;时间复杂度是O#xff08;N* logN#xff09;#xff0c;但是坏处就是如果排序的是一个逆序的数组的时候#xff0c;时间复杂度是O#xff08;N^2#xff09;,还不用我们的插入… 我们今天来讲讲八大排序中的快速排序快速排序最明显的特点就是排序快时间复杂度是ON* logN但是坏处就是如果排序的是一个逆序的数组的时候时间复杂度是ON^2,还不用我们的插入排序好所以特点明显但是缺点也是很明显的那我们开始今天的学习吧。 首先就是我们霍尔大佬的排序方法思想就是一遍排序让大的在右边小的都在左边我们来看看下面的动图. 我们可以看到霍尔大佬的排序方法有很多坑的首先我们是右边开始先找右边是找小找到小的时候停下来然后就是我们左边开始动左边是找到到找到大的时候就开始交换左边和右边然后再开始我们右边开始找大左边开始找小我们这里还是需要注意的就是我们这个排序什么时候才是结束的时候我们就是条件通过动图可以看到就是right和left相遇的时候然后这个时候我们需要做的就是交换key和left和rigth相遇地方的值。 这里的唯一难处就是我们为什么他们相遇的时候这个值一定是比key小的 我们left和right相遇有两种情况一种是right与left相遇一种是left和right相遇这两种相遇都是能够确保我们遇到的值是比key小的我们可以这样来看第一种情况right动left不动我们的right是找小 当right遇到left的时候left的位置肯定是小于key的我们上一次交换的时候就是把left变成小的所以这样也就确保right和left相遇的时候是比key小的我们再来看第二种情况就是left去遇到right因为right是找到小的值然后我们left去找大一直没找到大的时候就是到right这个时候条件也不满足了所以这样left和right碰到时候条件也是比key小。 但是这个都是因为我们是右边开始先找小的然后左边开始找大的如果没有这个条件的话我们是无法成立left和right相遇的时候值是比key小的。 代码如下 void Swap(int* p1, int* p2) {int tmp *p1;*p1 *p2;*p2 tmp; } int SortPart1(int* a, int left, int right) {int key a[left];int begin left;while (left right){while (left right a[right] key){right--;}while (left right a[left] key){left;}Swap(a[left], a[right]);}Swap(a[left], a[begin]);return left; }void QuickSort(int* a, int begin, int end) {if (begin end){return;}int midi Midi(a, begin, end);Swap(a[begin], a[midi]);int keyi SortPart3(a, begin, end);QuickSort(a, begin, keyi - 1);QuickSort(a, keyi1, end);} 这样就是我们霍尔大佬的思路但是霍尔大佬的写法坑是太对了大家可以看我们的代码是很容易写错的那我们来看看其他的版本再看其他版本的时候我们可以优化我们的代码就是我们的三数取中因为我们的代码逆序的时候是最慢的所以我们每次取值的时候如果我们的值每次不是最大和最小就很好的解决了我们的这个问题下面是三数取中的代码。 int Midi(int* a, int left, int right) {int mid (left right) / 2;if (a[mid] a[left]){if (a[right] a[mid]){return mid;}else if (a[right] a[left]){return left;}else{return right;}}else//left mid{if (a[right] a[left]){return left;}else if (a[right] a[mid]){return mid;}else{return right;}} } 我们来看看挖空法的动图。 我们先给出代码然后对着代码和图来看让大家更好的理解挖空法。 int Midi(int* a, int left, int right) {int mid (left right) / 2;if (a[mid] a[left]){if (a[right] a[mid]){return mid;}else if (a[right] a[left]){return left;}else{return right;}}else//left mid{if (a[right] a[left]){return left;}else if (a[right] a[mid]){return mid;}else{return right;}} }void Swap(int* p1, int* p2) {int tmp *p1;*p1 *p2;*p2 tmp; }int SortPart2(int* a, int left, int right) {int hole left;int key a[hole];while (left right){while (left right a[right] key){right--;}a[hole] a[right];hole right;while (left right a[left] key){left;}a[hole] a[left];hole left;}a[hole] key;return hole; }void QuickSort(int* a, int begin, int end) {if (begin end){return;}int midi Midi(a, begin, end);Swap(a[begin], a[midi]);int keyi SortPart3(a, begin, end);QuickSort(a, begin, keyi - 1);QuickSort(a, keyi1, end);} 挖空法的思路其实和霍尔大佬的思想很相似我们首先一定要保存坑位的数据因为等等这个数据想当于要被挖空是个空位我们记住这个hole是坑位的下标然后就是key是这个坑位的值我们先是右边开始找小的找到小的把这个位置填到到hole那个坑位里然后就是当前right位置就是新的坑位左边开始找大找到大的时候就是再和右边一样我们把右边的坑位拿左边的值填上再来左边挖坑最后left和right遇到的时候就是结束的时候。结束的时候就是最后的坑位最后的坑位补上我们刚开始的时候的值。 下一个就是我们的前后指针法 我们还是先来看看我们的动图。 前后指针法的我觉得看图就是能够写出代码的就是cur再找小找到小的时候pre要先然后再次进行交换就行了cur到最后结束所以结束条件就是cur end我们的代码可以优化成下面的这个代码。  int Midi(int* a, int left, int right) {int mid (left right) / 2;if (a[mid] a[left]){if (a[right] a[mid]){return mid;}else if (a[right] a[left]){return left;}else{return right;}}else//left mid{if (a[right] a[left]){return left;}else if (a[right] a[mid]){return mid;}else{return right;}} } void Swap(int* p1, int* p2) {int tmp *p1;*p1 *p2;*p2 tmp; }int SortPart3(int* a, int left, int right) {int pre left;int cur left 1;int begin left;int end right;while (cur end){if (a[cur] a[begin] pre ! cur){Swap(a[cur], a[pre]);}cur;}Swap(a[pre], a[begin]);return pre; } void QuickSort(int* a, int begin, int end) {if (begin end){return;}int midi Midi(a, begin, end);Swap(a[begin], a[midi]);int keyi SortPart3(a, begin, end);QuickSort(a, begin, keyi - 1);QuickSort(a, keyi1, end);} 那这样我们的前后指针法也是完成了这三种方法都是递归的方法吗现在下面来讲讲我们的非递归的方法非递归的方法首先是要有个栈的我们先得有个栈以前的文章有·栈吗大家也可以用我这个现场简略版的栈。 #includestdio.h #includeassert.h #includestdlib.h #includestdbool.htypedef int STDateType; typedef struct Stack {STDateType* a;int top;int capacity; }ST;void Init(ST* ps);void Push(ST* ps, STDateType x);void Pop(ST* ps);STDateType Top(ST* ps);void Dstory(ST* ps);bool Empty(ST* ps);int Size(ST* ps);#includestack.hvoid Init(ST* ps) {assert(ps);ps-a NULL;ps-capacity 0;ps-top -1; }void Push(ST* ps, STDateType x) {assert(ps);if (ps-top 1 ps-capacity){int newcapacity ps-capacity 0 ? 4 : ps-capacity * 2;STDateType* tmp (STDateType*) realloc(ps-a, sizeof(STDateType) * newcapacity);if (tmp NULL){perror(realloc fail);exit(-1);}ps-capacity newcapacity;ps-a tmp;}ps-top;ps-a[ps-top] x; }void Pop(ST* ps) {assert(ps);assert(ps-top 0);ps-top--; }void Dstory(ST* ps) {assert(ps);free(ps-a);ps-a NULL;ps-capacity ps-capacity 0; }STDateType Top(ST* ps) {assert(ps);return ps-a[ps-top]; }bool Empty(ST* ps) {assert(ps);return ps-top -1; }int Size(ST* ps) {assert(ps);return ps-top 1; }有了这个栈之后我们的非递归的思路其实就是边界问题我们的栈存储的不是我们数组的值而是我们每次的begin和end这些下标的值我们一开始push的值肯定是0和end我们也一定要注意push的顺序然后再取出来left和right。我们来看看这个图例子是这个数组。 我们的代码就是下面的这个。 //非递归 void QuickSortNonR(int* a, int n) {int begin 0;int end n - 1;ST st;Init(st);Push(st, end);Push(st, begin);while (!Empty(st)){int left Top(st);Pop(st);int right Top(st);Pop(st);int keyi SortPart3(a, left, right);if (left keyi - 1){Push(st, keyi-1);Push(st, left);}if (right keyi 1){Push(st, right);Push(st, keyi1);}}Dstory(st); } 今天分享的就是我们八大排序的快速排序快速排序是很重要的一个排序还有一个快速排序还是可以针对我们的很多重复值的排序比如一堆222222这些种我们放在后面的OJ题里面来讲他下一个分享的就是归并排序。我们下次再见。
http://www.zqtcl.cn/news/82543/

相关文章:

  • 怎么做有邀请码的网站关于建设网站的情况说明
  • 韩国网站免费观看常州网站建设推广平台
  • 网站搭建者wordpress无法开启多站点
  • wordpress建站的利弊wordpress get attachment
  • 太原网站开发模板无锡开发公司
  • 济南网站建设与维护网络建设方案模板
  • 无锡做网站优化价格saas建站没有网站源代码么
  • 制作个人网站步骤广东省公共资源交易中心平台
  • 如何能去医疗网站做编辑手机网站建设视频
  • 顺德电子画册网站建设wordpress 路径文件
  • 网站推广系统方案戴南网站建设
  • 手机wap网站定位手表到哪个网站买
  • 建站推广网站做网站前怎么写文档
  • wordpress问候插件做优化网站能以量取胜么
  • 我要发布文章到网站上推广 哪些网站最好个人建站步骤
  • 网站宣传的优点我想做个网站推广怎么做
  • 自建博客网站旅游网站建设答辩ppt
  • 网站开发技术难点博文阅读网站建设
  • 网站不足之处石家庄北国商城
  • 南昌优化网站分析代做ppt
  • 济南网站建设销售招聘中国地图36个省的地图
  • 搜索引擎优化网站的网址wordpress提货下载
  • 网站建设seo基本要求做外贸网站那个平台好
  • 怎样登录韵网网站涂料网站建设
  • 学做网站要会哪些嘉兴建设网站
  • 湛江网站制作工具重庆市建设工程信息网官方
  • 网络建设网站有关知识蓝希菏泽网站建设
  • 设计网站的合同wordpress批量注册会员
  • 网站上截小屏幕 怎么做南昌网站做
  • 制作制作网站建设的那些网站可做国外零售