高级排序算法:归并排序(优化版)

题目描述

leecode第912题:排序数组:

给你一个整数数组 nums,请你将该数组升序排列。

示例 1:

cpp 复制代码
输入:nums = [5,2,3,1]
输出:[1,2,3,5]

示例 2:

cpp 复制代码
输入:nums = [5,1,1,2,0,0]
输出:[0,0,1,1,2,5]

提示:

cpp 复制代码
1 <= nums.length <= 5 * 104
-5 * 104 <= nums[i] <= 5 * 104

代码:

cpp 复制代码
//归并排序优化
class Solution {
public:
    vector<int> sortArray(vector<int>& nums) {
        int len = nums.size();

        //优化1:全局使用一份临时数组
        int *temp = new int[len];
        mergeSort(nums, 0, len - 1, temp);
        return nums;
    }

    void mergeSort(vector<int>& nums, int left, int right, int* temp){
        if(right == left){
            return;
        }
        int mid = left + (right - left)/2;
        
        mergeSort(nums, left, mid, temp);
        mergeSort(nums, mid + 1, right, temp);
        //优化2:在两部分数组已经有序的情况下,不再合并
        if(nums[mid] < nums[mid+1]){
            return;
        }
        mergeOfTwoSortedArray(nums, left, mid, right, temp);
    }


    void mergeOfTwoSortedArray(vector<int>& nums, int left, int mid, int right, int* temp){
        for(int i = left; i<=right; i++){
            temp[i] = nums[i];
        }

        int i = left, j = mid + 1;
        for(int k = left; k<=right; k++){
            if(i == mid+1){
                nums[k] = temp[j];
                j++;
            }
            else if(j == right + 1){
                nums[k] = temp[i];
                i++;
            }

            else if(temp[i] <= temp[j]){//这一行的else没写曾经耗费了很长时间排查
                nums[k] = temp[i];
                i++;
            }
            else if(temp[i] > temp[j]){
                nums[k] = temp[j];
                j++;
            }
        }
    }
};
相关推荐
人生在勤,不索何获-白大侠几秒前
day15——Java常用API(二):常见算法、正则表达式与异常处理详解
java·算法·正则表达式
小张成长计划..13 分钟前
双向链表的实现
数据结构·链表
s1533519 分钟前
数据结构之顺序表,链表,栈,队列
数据结构·数据库
Wo3Shi4七35 分钟前
双向队列
数据结构·算法·go
Wo3Shi4七39 分钟前
列表
数据结构·算法·go
Wo3Shi4七1 小时前
链表
数据结构·算法·go
Wo3Shi4七1 小时前
数组
数据结构·算法·go
CoovallyAIHub1 小时前
YOLOv13都来了,目标检测还卷得动吗?别急,还有这些新方向!
深度学习·算法·计算机视觉
北方有星辰zz1 小时前
数据结构:栈
java·开发语言·数据结构
zl_dfq1 小时前
数据结构之 【树的简介】(树的(相关)概念、二叉树的概念、部分性质、满二叉树、完全二叉树)
数据结构