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];
    }
};
相关推荐
fpcc6 分钟前
信号处理与AI中的卷积的关系
c++·人工智能·信号处理
iiiiyu14 分钟前
面向对象高级接口的综合案例
java·开发语言·数据结构·编程语言
Mem0rin27 分钟前
[Java/数据结构]二叉树练习题几则
java·开发语言·数据结构
圣保罗的大教堂29 分钟前
leetcode 2069. 模拟行走机器人 II 中等
leetcode
地平线开发者35 分钟前
目标检测的 Anchor-Free 和 NMS 到底是什么?
算法·自动驾驶
北顾笙9801 小时前
day24-数据结构力扣
数据结构·算法·leetcode
t***5441 小时前
能否给出更多现代C++设计模式的示例
开发语言·c++·设计模式
梵尔纳多1 小时前
OpenGL 骨骼动画
c++·图形渲染·opengl
LG.YDX1 小时前
笔试训练48天:倒置字符串
数据结构
智者知已应修善业1 小时前
【51单片机独立按键控制往复流水灯启停】2023-6-13
c++·经验分享·笔记·算法·51单片机