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

如何优化公司的网站推广普通话的意义

如何优化公司的网站,推广普通话的意义,上海it驻场服务外包,杭州平台网站建设一、什么是归并排序 1、整体是递归,左边排好序右边排好序merge让整体有序 2、让其整体有序的过程里用了排外序方法 3、利用master公式来求解时间复杂度 4、当然可以用非递归实现 二、归并排序说明 1、首先有一个f函数 void f(arr, L, R) 说明:在arr上…

一、什么是归并排序

1、整体是递归,左边排好序+右边排好序+merge让整体有序
2、让其整体有序的过程里用了排外序方法
3、利用master公式来求解时间复杂度
4、当然可以用非递归实现

二、归并排序说明

1、首先有一个f函数
void f(arr, L, R)
说明:在arr上,从L到R范围上让它变成有序的

2、递归调用

(1)先f(L, M)之间有序
(2)f(M+1, R)之间有序
(3)变成整体有序

左边是2、3、5,右边是0,5,6
准备一个一样长的辅助空间,然后左指针指向2,右指针指向0,谁小拷贝谁
然后右边的指针往后移,再次比较2和5,谁小拷贝谁,以此类推

(4)整体有序后,再把这一块空间刷回去

三、代码

package class03;public class Code01_MergeSort {/*** 变成整体有序* @param arr* @param L 数组下标* @param M 数组下标* @param R 数组下标*/public static void merge(int[] arr, int L, int M, int R) {int [] help = new int[R - L + 1];int i = 0;int p1 = L;int p2 = M + 1;while (p1 <= M && p2 <= R) {help[i++] = arr[p1] <= arr[p2] ? arr[p1++] : arr[p2++];}//要么p1越界了,要么p2越界了//看左边小于等于Mwhile (p1 <= M) {help[i++] = arr[p1++];}//还是右边小于等于Rwhile (p2 <= R) {help[i++] = arr[p2++];}for (i = 0; i < help.length; i++) {arr[L + i] = help[i];}}/*** 递归方法实现* arr[L...R]范围上,变成有序* @param arr*/public static void mergeSort1(int[] arr) {if (arr == null || arr.length < 2) {return;}process(arr, 0, arr.length - 1);}public static void process(int[] arr, int L, int R) {if (L == R) { // base casereturn;}int mid = L + ((R - L) >> 1);process(arr, L, mid);process(arr, mid + 1, R);merge(arr, L, mid, R);}/*** 非递归方法实现* @param arr*/public static void mergeSort2(int[] arr) {if (arr == null || arr.length < 2) {return;}int N = arr.length;int mergeSize = 1;while (mergeSize < N) {int L = 0;while (L < N) {int M = L + mergeSize - 1;if (M >= N) {break;}int R = Math.min(M + mergeSize, N - 1);merge(arr, L, M, R);L = R + 1;}if (mergeSize > N / 2) { //防止溢出break;}mergeSize <<= 1; //左移后赋值,相当于乘2后赋值}}public static void main(String[] args) {int[] aaa = {99, 100, 50, 70, 88, 10, 9, 35, 1, 98};int[] bbb = {99, 100, 50, 70, 88, 10, 9, 35, 1, 98};mergeSort1(aaa);for (int i: aaa) {System.out.print(i + " ");}System.out.println();mergeSort2(bbb);for (int i: bbb) {System.out.print(i + " ");}System.out.println();}
}

(1)递归说明

(2)非递归说明

原理:
k=2
相邻两个数之间merge在一起
k=4
四个数一组,merge在一起
...
一直到k到达N或者超过N

回到代码,代码中mergeSize就是k,外层while循环
  N  10
  mergeSize  1
  L  0
  内层while循环
    M  0
    R  1
    merge(arr, 0, 0, 1)
    L  2
    
    M  2
    R  3
    merge(arr, 2, 2, 3)
    L  4
    
    M  4
    R  5
    merge(arr, 4, 4, 5)
    L  6
    
    ...

然后mergeSize变成2,变成4...

四、归并排序复杂度

T(N)=2*T(N/2)+O(N^1)
根据master可知时间复杂度为O(N*logN)
merge过程需要辅助数组,所以额外空间复杂度为O(N)
归并排序的实质是把比较行为变成了有序信息并传递,比O(N^2)的排序快

http://www.hengruixuexiao.com/news/15517.html

相关文章:

  • 机械行业营销型网站b2b平台营销
  • 网站左侧广告代码写软文怎么接单子
  • 巴州网站建设班级优化大师的功能
  • 建设银行网银网站激活广东seo网站优化公司
  • 怎么做网站超链接seo推荐
  • 成都怎么成立网站免费网上申请注册
  • 电视台网站模版seo网站内部优化方案
  • 仿做静态网站多少钱湖南知名网络推广公司
  • 成品网站管理系统2024年重大新闻简短
  • 三大门户网站是什么seo优化外链平台
  • 网站首页滚动图片百度广告代理商加盟
  • 模板网站官网公司官网搭建
  • 有了域名之后怎么做网站营销策略有哪些内容
  • 做擦边网站 服务器放在狗爹东莞seo顾问
  • 无锡网站策划公司win7优化
  • 广东网站建设开发怎样制作一个网页
  • 发票 网站建设 单位网站制作策划书
  • app开发 上传wordpress兰州seo
  • 初创企业网站建设流程最近发生的新闻
  • 中国建设人才服务信息网是不是正规网站整站优化包年
  • hexo和wordpress网站seo入门基础教程
  • 宁波建设网图百度搜索引擎优化公司哪家强
  • 企业网站开发公司-北京公司网络营销专业
  • 电商网站开发需求文档个人发布信息免费推广平台
  • wordpress建站安全性手游推广渠道和推广方式
  • wordpress 数据交互国外搜索引擎优化
  • 制作简单的个人网站如何制作网站赚钱
  • b2b b2c 平台网站建设方案大连seo顾问
  • 可以做ppt的网站有哪些方面广州的百度推广公司
  • 哔哩哔哩官方网站首页深圳推广系统