力扣88. 合并两个有序数组(双指针)
https://leetcode-cn.com/problems/merge-sorted-array/
给你两个有序整数数组 nums1 和 nums2,请你将 nums2 合并到 nums1 中,使 nums1 成为一个有序数组。
说明:
初始化 nums1 和 nums2 的元素数量分别为 m 和 n 。
你可以假设 nums1 有足够的空间(空间大小大于或等于 m + n)来保存 nums2 中的元素。
示例:
输入:
nums1 = [1,2,3,0,0,0], m = 3
nums2 = [2,5,6], n = 3
输出: [1,2,2,3,5,6]
思路:双指针
双指针 / 从前往后
复杂度分析
- 时间复杂度 : O(n + m)。
- 空间复杂度 : O(m)。
#include "stdafx.h"
#include<vector>
#include <iostream>
using namespace std;
class Solution
{
public:
void merge(vector<int>& nums1, int m, vector<int>& nums2, int n)
{
vector<int>result;
int i = 0;
int j = 0;
//nums1和nums2都有的情况下,较小的那个值先放
while (i <= m - 1 && j <= n - 1)
{
if (nums1[i] >= nums2[j])
{
result.push_back(nums2[j]);
j++;
}
else
{
result.push_back(nums1[i]);
i++;
}
}
//如果nums1还有剩余,接在result后面
while (i <= m - 1)
{
result.push_back(nums1[i]);
i++;
}
//如果nums2还有剩余,接在result后面
while (j <= n - 1)
{
result.push_back(nums2[j]);
j++;
}
//将结果赋值给nums1[k]
for (int k=0;k<m+n;k++)
{
nums1[k] = result[k];
}
}
};
int main()
{
Solution s;
vector<int> nums1;
nums1.push_back(1); nums1.push_back(2); nums1.push_back(3);
nums1.push_back(0); nums1.push_back(0); nums1.push_back(0);
vector<int> nums2;
nums2.push_back(2); nums2.push_back(5); nums2.push_back(6);
//打印nums1
cout << "打印nums1:" << '\n';
for (int i=0;i<nums1.size();i++)
{
cout << nums1[i] << '\t';
}
//打印nums2
cout << '\n' << "打印nums2:" << '\n';
for (int i = 0; i < nums2.size(); i++)
{
cout << nums2[i] << '\t';
}
//合并
cout << '\n' << "合并nums1和nums2:" << '\n';
s.merge(nums1, 0, nums2, 0);
//打印nums1
cout << '\n' << "打印nums1:" << '\n';
for (int i = 0; i < nums1.size(); i++)
{
cout << nums1[i] << '\t';
}
//打印nums2
cout << '\n' << "打印nums2:" << '\n';
for (int i = 0; i < nums2.size(); i++)
{
cout << nums2[i] << '\t';
}
return 0;
}
双指针 / 从后往前
看了官方答案后,发现一种更厉害的方法:
复杂度分析
- 时间复杂度 : O(n + m)。
- 空间复杂度 : O(1)。
双指针 / 从后往前