前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >(Leetcode 2021 刷题计划) 88. 合并两个有序数组

(Leetcode 2021 刷题计划) 88. 合并两个有序数组

原创
作者头像
windism
修改2021-04-06 11:03:39
2540
修改2021-04-06 11:03:39
举报
文章被收录于专栏:风扬风扬

每日一题时间: 2020-04-05 题目链接: 88. 合并两个有序数组 官方题解链接: 合并两个有序数组

题目

给你两个有序整数数组 nums1nums2,请你将 nums2 合并到 nums1 中,使 nums1 成为一个有序数组。

初始化 nums1nums2 的元素数量分别为 mn 。你可以假设 nums1 的空间大小等于 m + n,这样它就有足够的空间保存来自 nums2 的元素。

代码语言:txt
复制
示例 1:
输入:nums1 = [1,2,3,0,0,0], m = 3, nums2 = [2,5,6], n = 3
输出:[1,2,2,3,5,6]
示例 2:
输入:nums1 = [1], m = 1, nums2 = [], n = 0
输出:[1]

提示:

  • nums1.length == m + n
  • nums2.length == n
  • 0 <= m, n <= 200
  • 1 <= m + n <= 200
  • -109 <= nums1[i], nums2[i] <= 109

解题方法

尾部遍历

解题思路: 从尾部新增可以保证不会对前面的顺序进行改变(覆盖或错位)或无需借助额外数据。

代码语言:txt
复制
class Solution {
public:
    void merge(vector<int>& nums1, int m, vector<int>& nums2, int n) {
        --m; --n;
        while(m >= 0 && n >= 0) {
            if (nums1[m] < nums2[n]) {
                nums1[m + n + 1] = nums2[n];
                --n;
            } else {
                nums1[m + n + 1] = nums1[m];
                --m;
            }
        }
        while (n >= 0) {
            nums1[n] = nums2[n];
            --n;
        }
    }
};
  • 复杂度分析
    • 时间复杂度: O(M + N)
    • 空间复杂度: O(1)

参考资料

  1. 88. 合并两个有序数组
  2. 合并两个有序数组

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目
  • 解题方法
    • 尾部遍历
    • 参考资料
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档