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

深圳做网站的公司那个好做网站包括什么条件

深圳做网站的公司那个好,做网站包括什么条件,可视化网站建设软件,平面设计公司怎么找客户之前我们学习过把两个有序数组合并再一起后任然有序,就叫归并; 那么,排序是否也可以把一个要排序的数组分割成两个有序的数组,然后归并,之后再拷贝回原数组,就实现了排序 但是怎么才能控制分割成的数组是有…

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

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

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.yayakq.cn/news/762611/

相关文章:

  • 怎么用ps做网站首页图片尺寸wordpress提示框插件
  • 做外贸用什么社交网站工业和信息化部反诈中心发短信
  • 免费注册qq号网站哪些网站是做食品
  • 网站建设营销模板湖州市交通建设管理局网站
  • 网站做nat映射需要哪些端口wap免费
  • 昆山做网站好的山西推广网站建设
  • 现在的公司都有自己的网站吗自助建站网信息发布平台
  • 网站的模版可以换吗网络营销公司做得比较好的
  • 环保网站建设价格网站开发石家庄
  • 网站注册转化率手机网站免费的
  • 宣传模板关键词优化公司如何选择
  • 上海有哪些做网站网上做网站
  • 做网站需要什么文件长宁区网站建设公司
  • 网站推广和优化的原因用django做网站
  • 建立网站的费用短视频剪辑培训班多少钱
  • 东莞网站的制作无锡信息网站建设
  • 做网站多少钱PageAdmin网站推广营销公司
  • 随州市网站建设手机免费app开发制作平台
  • 自己做配图的网站企业网站栏目设计
  • 马鞍山集团网站设计西安网站seo
  • 运营商做网站wordpress文章无法使用
  • 广州祥云平台网站建设网站制作过程简介
  • 网页设计与网站建设案例教程msn wordpress
  • 手机微网站模板下载手机网站主机
  • wordpress高级破解主题什么是优化产业结构
  • 平台和自建网站服务提供者查看网站被恶意镜像
  • 怎么查看服务器上的网站生活分类信息网站大全
  • 服装网站设计策划同城分类网站建设
  • 网站排名优化培训哪家好快速网站
  • 以网站建设为开题报告自己接私单网站开发