每日一题时间:
2020-04-05
题目链接: 88. 合并两个有序数组 官方题解链接: 合并两个有序数组
给你两个有序整数数组 nums1
和 nums2
,请你将 nums2
合并到 nums1
中,使 nums1 成为一个有序数组。
初始化 nums1
和 nums2
的元素数量分别为 m
和 n
。你可以假设 nums1
的空间大小等于 m + n
,这样它就有足够的空间保存来自 nums2
的元素。
示例 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
解题思路: 从尾部新增可以保证不会对前面的顺序进行改变(覆盖或错位)或无需借助额外数据。
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)
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。