分治思想对数组进行排序-归并排序

由于新手阶段的我对于归并的代码逻辑并不能很直观的理解代码的执行逻辑,所以本文我将会对于这个归并排序算法进行自我观点的总结,以便后续忘了,回来看看,能快速拾起思路.不会想现在每次都需要花很多时间去理解思路.

java 复制代码
/**
 * 归并排序
 */
数组nums={5,3,4,2,1}

public class Main {

    int[] tmp;
    
    public void mergeSort(int[] nums,int left,int right){
        if(left>=right) return;//判断数组是否符合原子性,及不能再分
        
        int mid=(left+right)/2;//按照mid=2下标进行数组拆分[5,3,4]和[2,1]
        
        mergeSort(nums,left,mid);//进入做递归
        mergeSort(nums,mid+1,right);//进入右递归

           
        //左右递归完后进行比较
        int cur1=left,cur2=mid+1,i=0;

        while(cur1<=mid && cur2<=right){
         //较小的元素放前面
            tmp[i++]=nums[cur1]<=nums[cur2]?nums[cur1++]:nums[cur2++];
        }
        
        //放入较大的元素
        while(cur1<=mid) tmp[i++]=nums[cur1++];
        while(cur2<=right) tmp[i++]=nums[cur2++];
        
        //将tmp排好数组赋值给nums
        for(int j=left;j<=right;j++) nums[j]=tmp[j-left];

    }

}

归并排序可以想成套娃的玩法,将一个复杂的问题分成多个简单的问题,进行解决,就能解决这个复杂的问题,这就是分治思想.归并排序执行顺序和二叉树前序遍历一模一样

相关推荐
数智工坊1 小时前
周志华《Machine Learning》学习笔记--第六章--支持向量机
笔记·神经网络·学习·算法·机器学习·支持向量机
casual~1 小时前
【学习记录】
学习·算法
社交怪人1 小时前
【奇偶ASCII值】信息学奥赛一本通C语言解法(题号1042)
算法
小欣加油2 小时前
leetcode3635 最早完成陆地和水上游乐设施的时间II
数据结构·c++·算法·leetcode
GUO_PP2 小时前
win11英雄联盟打开以后,自动改变音效,开启免提模式的问题修正
人工智能·算法
变量未定义~2 小时前
排列数字、 n-皇后问题
数据结构·算法
BirdenT3 小时前
20260604紫题训练
c++·算法
元启数宇3 小时前
疏散指示AI实战:规范布点与路径推演全流程
人工智能·算法
tg:;3 小时前
Catkin 常用命令
开发语言·c++·算法