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];
    }
};
相关推荐
星竹晨L4 小时前
【C++】类和对象(三)
c++
ftswsfb4 小时前
现代C++:现代C++?
开发语言·c++
乌萨奇也要立志学C++4 小时前
【C++详解】C++ 智能指针:使用场景、实现原理与内存泄漏防治
开发语言·c++
minji...5 小时前
C++ 详细讲解vector类
开发语言·c++
颖川守一5 小时前
c6-类和对象-对象特征-类对象做对象成员
c++
山河君5 小时前
webrtc之高通滤波——HighPassFilter源码及原理分析
算法·音视频·webrtc·信号处理
星辰大海的精灵5 小时前
SpringBoot与Quartz整合,实现订单自动取消功能
java·后端·算法
data myth5 小时前
力扣1210. 穿过迷宫的最少移动次数 详解
算法·leetcode·职场和发展
惯导马工5 小时前
【论文导读】AI-Assisted Fatigue and Stamina Control for Performance Sports on IMU-Gene
深度学习·算法