leetcode 912 排序数组(归并排序)

一、问题描述

二、解题思路

整体思路

由于本题需要使得数组进行升序排列,所以我们可以使用归并排序来解决这个问题。

具体思路

归并排序的思路如下:

(1)当left=>right即,区间里面只有1个元素或者没有元素时,表示无需排序,直接return;

(2)首先,寻找数组的中间位置mid=(right+left)>>1,为了防止溢出,我们写成mid=left+(right-left)/2;

(3)然后归并排序[left,mid]和[mid+1,right]两个区间,这里采用递归来实现;

(4)采用双指针来合并两个区间,将合并后的数组放入辅助数组tmp;

(5)还原nums数组,即将tmp中的元素移动到nums中。

三、代码实现

时间复杂度:T(n)=O(nlogn)

空间复杂度:S(n)=O(n)

cpp 复制代码
class Solution {
    vector<int> tmp;
public:
    vector<int> sortArray(vector<int>& nums) {
        tmp.resize(nums.size());
       mergeSort(nums,0,nums.size()-1);
       return nums;
    }
    //归并排序
    void mergeSort(vector<int>& nums,int left,int right){
        //递归出口
        if(left>=right) return;

        //1.寻找中间位置
        int mid=left+(right-left)/2;//防止溢出
        //2.对左右区间分别进行排序
        mergeSort(nums,left,mid);
        mergeSort(nums,mid+1,right);
        //3.归并左右区间(双指针)
        int l=left,r=mid+1,i=0;
        while(l<=mid&&r<=right)
            tmp[i++]=nums[l]<=nums[r]?nums[l++]:nums[r++];
        while(l<=mid) tmp[i++]=nums[l++];
        while(r<=right) tmp[i++]=nums[r++];
        //4.还原
        for(int i=left;i<=right;i++)
            nums[i]=tmp[i-left];
    }
};
相关推荐
高山上有一只小老虎1 小时前
字符串字符匹配
java·算法
愚润求学2 小时前
【动态规划】专题完结,题单汇总
算法·leetcode·动态规划
MOONICK2 小时前
数据结构——哈希表
数据结构·哈希算法·散列表
林太白2 小时前
跟着TRAE SOLO学习两大搜索
前端·算法
爱凤的小光2 小时前
图漾GM461-E1相机专栏
c++
ghie90902 小时前
图像去雾算法详解与MATLAB实现
开发语言·算法·matlab
云泽8082 小时前
从三路快排到内省排序:探索工业级排序算法的演进
算法·排序算法
qwepoilkjasd3 小时前
C++智能指针介绍
c++
weixin_468466853 小时前
遗传算法求解TSP旅行商问题python代码实战
python·算法·算法优化·遗传算法·旅行商问题·智能优化·np问题
·白小白3 小时前
力扣(LeetCode) ——43.字符串相乘(C++)
c++·leetcode