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

柳州免费做网站的公司合肥网站排名提升

柳州免费做网站的公司,合肥网站排名提升,沈阳世纪兴网站制作公司,装修网站建设归并排序主要是两大模块 分治 和 合并 即将已有序的子序列合并,得到完全有序的序列;即先使每个子序列有序,再使子序列段间有序。若将两个有序表合并成一个有序表,称为二路归并 由于使用了新的数组 那么空间复杂度就为O(n) 但这…

归并排序主要是两大模块 分治 和 合并  

即将已有序的子序列合并,得到完全有序的序列;即先使每个子序列有序,再使子序列段间有序。若将两个有序表合并成一个有序表,称为二路归并 由于使用了新的数组 那么空间复杂度就为O(n) 但这一排序会相同数据的位置保持不变即 保持数组的稳定性 

以[8, 4, 5, 7, 1, 3, 6, 2]为例

执行的顺序为

mergeSort(A, 0, 7)  // 处理整个数组

├── mergeSort(A, 0, 3)  // 处理左半部分

│   ├── mergeSort(A, 0, 1)  // 处理 [8, 4]

│   │   ├── mergeSort(A, 0, 0)  // 处理 [8](终止)

│   │   ├── mergeSort(A, 1, 1)  // 处理 [4](终止)

│   │   ├──  merge(A, 0, 1, temp)  // 合并 [8] 和 [4]

│   ├── mergeSort(A, 2, 3)  // 处理 [5, 7]

│   │   ├── mergeSort(A, 2, 2)  // 处理 [5](终止)

│   │   ├── mergeSort(A, 3, 3)  // 处理 [7](终止)

│   │   ├──  merge(A, 2, 3, temp)  // 合并 [5] 和 [7]

│   ├──  merge(A, 0, 3, temp)  // 合并 [4, 8] 和 [5, 7]

├── mergeSort(A, 4, 7)  // 处理右半部分

│   ├── mergeSort(A, 4, 5)  // 处理 [1, 3]

│   │   ├── mergeSort(A, 4, 4)  // 处理 [1](终止)

│   │   ├── mergeSort(A, 5, 5)  // 处理 [3](终止)

│   │   ├── merge(A, 4, 5, temp)  // 合并 [1] 和 [3]

│   ├── mergeSort(A, 6, 7)  // 处理 [6, 2]

│   │   ├── mergeSort(A, 6, 6)  // 处理 [6](终止)

│   │   ├── mergeSort(A, 7, 7)  // 处理 [2](终止)

│   │   ├── merge(A, 6, 7, temp)  // 合并 [6] 和 [2]

│   ├──  merge(A, 4, 7, temp)  // 合并 [1, 3] 和 [2, 6]

├──  merge(A, 0, 7, temp)  // 合并 [4, 5, 7, 8] 和 [1, 2, 3, 6]

关键点在于

 mergeSort() 先递归拆分,直到 start == end(单个元素),然后回溯时合并

merge() 只在两个子数组都已经排序后才会执行

merge() 总是在 mergeSort() 递归调用之后执行,保证子数组是有序的再进行合并

类似于二叉树的后续遍历 即左右根

          [8, 4, 5, 7, 1, 3, 6, 2]

          /                       \

  [8, 4, 5, 7]                   [1, 3, 6, 2]

     /         \                   /         \

  [8, 4]     [5, 7]             [1, 3]     [6, 2]

   /    \     /    \            /    \      /    \

 [8]    [4] [5]    [7]        [1]    [3]  [6]    [2]

下面为实现的代码

public class Solution {

    public void sortIntegers2(int[] A) {

       if(A==null||A.length<=0)

       {

           return;

       }

       int[] temp=new int[A.length];

       mergeSort(A,0,A.length-1,temp);

    }

    void mergeSort(int[] A,int start,int end,int[] temp)

    {

        if(start>=end)

        {

            return;

        }

        int mid=(start+end)/2;

        //递归将其分治 将所有的数字最终分解为一个元素

        mergeSort(A,start,mid,temp);

        mergeSort(A,mid+1,end,temp);

      //递归完成后进行合并已排好序的数组 

        merge(A,start,end,temp);

    }

    void merge(int[] A,int start,int end,int[] temp)

    {

        int middle = (start + end) / 2;

        int leftIndex=start;

        int rightIndex=middle+1;

        int Index=start;

        //比较两个左右子数列 按照从小打大的顺序进行排序

        while(leftIndex<=middle&&rightIndex<=end)

        {

            if(A[leftIndex]<=A[rightIndex])

            {

                temp[Index++]=A[leftIndex++];

            }else

            {

                temp[Index++]=A[rightIndex++];

            }

        }

        //将余下的左子序列赋值至剩余的temp数组中

        while(leftIndex<=middle)

        {

        temp[Index++]=A[leftIndex++];

        }

        //将余下的右子序列赋值至剩余的temp数组中

        while(rightIndex<=end)

        {

        temp[Index++]=A[rightIndex++];

        }

        for(int i=start;i<=end;i++)

        {

            A[i]=temp[i];

        }

    }

    }

http://www.dtcms.com/wzjs/161984.html

相关文章:

  • 佛山网站建设佛山谷歌官方网站注册
  • 制作网页网站2022年近期重大新闻事件
  • 哪里免费做网站google首页
  • 广州seo网站靠谱seo 网站排名
  • yahoo网站提交入口营销推广手段有什么
  • 免费中文企业网站模板百度sem推广具体做什么
  • 企业网站的建立联系方式seo线下培训机构
  • 软件开发与网站开发手机最新产品新闻
  • 上海 餐饮网站建设微平台推广
  • 跨境电商代运营公司十强网站关键词优化排名外包
  • java做网站建设后台b站推广入口2023mmm
  • 通过模版做网站搜索引擎推广的关键词
  • 深圳做手机商城网站建设2021拉新推广佣金排行榜
  • 初学php者网站首页怎么做品牌推广与传播
  • 长沙企业建站系统百度网页
  • 在线ppt制作网站有哪些站长推荐产品
  • 南京网站建设知识做任务赚佣金的正规平台
  • 做网站被骗去哪投诉百度竞价推广培训
  • 衡水网站建设公司联系电话seo技术培训海南
  • 义乌购物网站建设多少钱网站快速建站
  • 网站客服弹窗代码马鞍山seo
  • 建设网站材料可以下载吗石家庄自动seo
  • 百度公司做网站可靠吗樱花bt引擎
  • 临沂网站制作网站近两年成功的网络营销案例
  • 和人妖做的视频网站长沙市云网站建设
  • 做外围什么网站有客户2023年6月份疫情严重吗
  • 成功网站建设案例网络营销师课程
  • 深圳市建设工程交易中心网站如何免费推广网站
  • 凡科网站是什么做的2022年五月份热点事件
  • 佛山专业英文网站建设学生个人网页设计模板