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

一览英才网招聘信息网aso排名优化知识

一览英才网招聘信息网,aso排名优化知识,三维培训学费一般多少,最新备案的网站之前我们学习过把两个有序数组合并再一起后任然有序,就叫归并; 那么,排序是否也可以把一个要排序的数组分割成两个有序的数组,然后归并,之后再拷贝回原数组,就实现了排序 但是怎么才能控制分割成的数组是有…

之前我们学习过把两个有序数组合并再一起后任然有序,就叫归并;
在这里插入图片描述
那么,排序是否也可以把一个要排序的数组分割成两个有序的数组,然后归并,之后再拷贝回原数组,就实现了排序
但是怎么才能控制分割成的数组是有序的呢,
当:
在这里插入图片描述
当数组中只有两个数的时候,我们进行分割后,每一个数组就只有一个数,就可以看成有序的

有了这个思想,那么我们就递归分个要排序的数组,当递归分割到只有两个数的时候,在归并
在这里插入图片描述

void Merge(int* a, int* tmp, int begin, int end)
{//分割if (begin == end){return;}int mid = (begin + end) / 2;Merge(a, tmp, begin, mid);Merge(a, tmp, mid + 1, end);//归并int begin1 = begin;int end1 = mid;int begin2 = mid + 1;int end2 = end;int dex = begin;while (begin1<=end1&&begin2<=end2){if (a[begin1] <= a[begin2]){tmp[dex] = a[begin1];dex++;begin1++;}else{tmp[dex] = a[begin2];dex++;begin2++;}}while (begin1 <= end1){tmp[dex] = a[begin1];dex++;begin1++;}while (begin2 <= end2){tmp[dex] = a[begin2];dex++;begin2++;}//拷贝回去memcpy(a + begin, tmp + begin, (end - begin + 1) * sizeof(int));}
void MergeSort(int* a, int n)
{int* tmp = (int*)malloc(sizeof(int) * n);Merge(a,tmp,0,n-1);
}

非递归的写法:
之前的快速排序是借助栈来实现非递归,因为每次分完之后他就找出了key的位置,那个区间出栈后不需要再用到
但是归并排序的话,分割完后,还要用到之前的分割区间,但是都已经出栈了,就找不到了。所以归并排序的非递归不能用栈来实现
在这里插入图片描述
但是这样的归并方式只适合数组中的元素个数是2的指数倍,如果我们要适合其他区任何个数的话在划分区间归并的时候还的判断是否越界
在这里插入图片描述
代码:

void MergeSortNoNs(int* a, int n)
{int* tmp = (int*)malloc(sizeof(int) * n);int pas = 1;while (pas<n){for (int i = 0; i < n; i += pas * 2){int begin1 = i; int end1 = i + pas - 1;int begin2 = i + pas; int end2 = i + 2 * pas - 1;//越界管理if (begin2 >= n){break;}if (end2 >= n){end2 = n - 1;}int dex = i;while (begin1 <= end1 && begin2 <= end2){if (a[begin1] <= a[begin2]){tmp[dex] = a[begin1];dex++;begin1++;}else{tmp[dex] = a[begin2];dex++;begin2++;}}while (begin1 <= end1){tmp[dex] = a[begin1];dex++;begin1++;}while (begin2 <= end2){tmp[dex] = a[begin2];dex++;begin2++;}//拷贝回去memcpy(a + i, tmp+i, (end2-i+1) * sizeof(int));}pas *= 2;}
}
http://www.ds6.com.cn/news/72999.html

相关文章:

  • 手机网站建设技术方案企业网站快速排名
  • 宁波网站推广多少钱一个免费发帖平台
  • 邢台123生活信息百度关键字优化
  • 网站开发公司前置审批招代理最好的推广方式
  • 如何网络推广优化保定百度seo公司
  • 手机做网站用什么怎么搜索网站
  • 阿土伯网站做产品推广咋样如何推广网站方法
  • 手机游戏开服表时间表网站怎样关键词排名优化
  • 建立网站的意义sem和seo的区别
  • 服务一流的做网站电脑培训班一般多少钱
  • 重庆网站建设排名营销手段有哪些方式
  • 网站建设服务平台b2b网站有哪些
  • 安徽平台网站建设设计灰色词快速上排名
  • wordpress轮播图设置手机优化软件哪个好用
  • 微信公众号个人可以做网站么杭州网站seo推广软件
  • 网站一般用什么做的网站开发培训
  • 做一电影网站怎么赚钱吗爱站数据
  • 深圳做商城网站推广怎么做
  • 网页作业班级网站怎么做网站很卡如何优化
  • 广州有什么好玩的地方免费的seo手机关键词网址
  • 中国建筑网测绍兴seo公司
  • 聊城建设网站百度官方
  • 企业如何免费做网站网站外包
  • 数码公司网站建设调查广告公司排名
  • 城阳做网站的微信软文范例100字
  • 手机网站 栏目定制百度搜索高级搜索
  • 推广型的网站怎么做培训方案怎么做
  • 网站建设的发展趋势北京网站优化推广公司
  • 手机版文章网站源码搜索引擎优化的主要特征
  • 怎样做淘宝客导购网站小红书怎么做关键词排名优化