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];
    }
};
相关推荐
前端摸鱼匠3 小时前
【AI大模型春招面试题11】什么是模型的“涌现能力”(Emergent Ability)?出现条件是什么?
人工智能·算法·ai·自然语言处理·面试·职场和发展
sqmw3 小时前
MFCMouseEffect:把桌面输入反馈这件事,做成一个真正可扩展的引擎
c++·插件·引擎·鼠标特效·键鼠指示·鼠标伴宠
MORE_774 小时前
leecode-合并区间-贪心算法
算法·贪心算法
沈阳信息学奥赛培训4 小时前
#undef 指令 (C/C++)
c语言·开发语言·c++
2401_873204654 小时前
分布式系统安全通信
开发语言·c++·算法
sw1213895 小时前
C++中的代理模式实战
开发语言·c++·算法
ballball~~5 小时前
ISP-CCM(Color Correction Matrix)
图像处理·数码相机·算法
sheeta19986 小时前
LeetCode 每日一题笔记 日期:2025.03.24 题目:2906.构造乘积矩阵
笔记·leetcode·矩阵
Sunshine for you6 小时前
实时操作系统中的C++
开发语言·c++·算法
史蒂芬_丁6 小时前
C++深度拷贝例子
java·开发语言·c++