力扣面试经典150 88. 合并两个有序数组 归并排序的merge函数

题目链接

规定了时间我首先想到的是归并排序,以时间换空间,题目要求时间复杂度O(m+n)

提示:

复制代码
nums1.length == m + n
nums2.length == n
0 <= m, n <= 200
1 <= m + n <= 200
-109 <= nums1[i], nums2[j] <= 109

而且这个题理论上,是合并,所以得把最后合并的结果放到nums1[]上

下面是代码

java 复制代码
class Solution {
public:
    void merge(vector<int>& nums1, int m, vector<int>& nums2, int n) {
   vector<int> temp(nums1.begin(),nums1.begin()+m);
   int p=0;
   int p1=0;
   int p2=0;
   while(p1<m&&p2<n){if(temp[p1]<=nums2[p2])
    nums1[p++]=temp[p1++];else
    nums1[p++]=nums2[p2++];
   }

while(p1<m)nums1[p++]=temp[p1++];
while(p2<n)nums1[p++]=nums2[p2++];


    }
};

然后再复习一下归并排序

这么多年了,发现自己学习算法过于死板

其实归并排序是一棵归并排序二叉树。

那么一涉及到树就很容易理解,这里头有递归,所以归并排序是由递归和merge函数组合来实现的,那个大的递归函数就是

java 复制代码
void mergeSort(vector<int>& arr, int l, int r){
if(l>=r) return;
int mid=(l+r)/2;
mergesort(arr,l,mid);
mergesort(arr,mid,r);
merge(arr,l,mid,r);
}

下面是完整的归并排序的代码

java 复制代码
#include <iostream>
#include <vector>
using namespace std;

// 合并两个有序区间 [l, mid] 和 [mid+1, r]
void merge(vector<int>& arr, int l, int mid, int r) {
    vector<int> temp(r - l + 1);
    int i = l;
    int j = mid + 1;
    int k = 0;

    while (i <= mid && j <= r) {
        if (arr[i] <= arr[j]) {
            temp[k++] = arr[i++];
        } else {
            temp[k++] = arr[j++];
        }
    }

    while (i <= mid) temp[k++] = arr[i++];
    while (j <= r) temp[k++] = arr[j++];

    // 复制回原数组
    for (int p = 0; p < temp.size(); ++p) {
        arr[l + p] = temp[p];
    }
}

// 归并排序递归
void mergeSort(vector<int>& arr, int l, int r) {
    if (l >= r) return;
    int mid = (l + r) / 2;
    mergeSort(arr, l, mid);
    mergeSort(arr, mid + 1, r);
    merge(arr, l, mid, r);
}

int main() {
    vector<int> arr = {5, 2, 9, 1, 5, 6, 3, 8};

    cout << "排序前:";
    for (int x : arr) cout << x << " ";
    cout << endl;

    mergeSort(arr, 0, arr.size() - 1);

    cout << "排序后:";
    for (int x : arr) cout << x << " ";
    cout << endl;

    return 0;
}

直接从后面替换插入的方法

java 复制代码
class Solution {
public:
    void merge(vector<int>& nums1, int m, vector<int>& nums2, int n) {
  int i=nums1.size()-1;
  n--;
  m--;
    while(n>=0){
        while(m>=0&&nums1[m]>nums2[n]){
            swap(nums1[i--],nums1[m--]);
        }
        swap(nums1[i--],nums2[n--]);
    }
    }
};
相关推荐
x_yeyue10 小时前
三角形数
笔记·算法·数论·组合数学
Patrick_Wilson10 小时前
知识沉淀的四层模型:从个人笔记到企业资产,让文档真正长出复利
面试·程序员·ai编程
橙序员小站11 小时前
人人都在鼓吹的OPC,我想给你泼盆冷水
面试·创业
念何架构之路11 小时前
Go语言加密算法
数据结构·算法·哈希算法
AI科技星11 小时前
《数学公理体系·第三部·数术几何》(2026 年版)
c语言·开发语言·线性代数·算法·矩阵·量子计算·agi
失去的青春---夕阳下的奔跑11 小时前
560. 和为 K 的子数组
数据结构·算法·leetcode
黎阳之光11 小时前
黎阳之光:以视频孪生重构智慧医院信息化,打造高标项目核心竞争力
大数据·人工智能·物联网·算法·数字孪生
丷丩12 小时前
三级缓存下MVT地图瓦片服务性能优化策略
算法·缓存·性能优化·gis·geoai-up
m0_6294947312 小时前
LeetCode 热题 100-----25.回文链表
数据结构·算法·leetcode·链表
ʚ希希ɞ ྀ13 小时前
单词拆分----dp
算法