Leetcode Tencent 50 Task 27 88. Merge Sorted Array

描述

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

说明:

  • 初始化 nums1nums2 的元素数量分别为 mn
  • 你可以假设 nums1 有足够的空间(空间大小大于或等于 m + n)来保存 nums2 中的元素。

示例:

1
2
3
4
5
输入:
nums1 = [1,2,3,0,0,0], m = 3
nums2 = [2,5,6], n = 3

输出: [1,2,2,3,5,6]

来源:力扣(LeetCode)
链接:88. Merge Sorted Array

解题思路

根据题意,本题的思路还是比较简单的,采用双指针,为了节省空间,直接从后往前,因为nums1数组足够大,那么所有的元素从大到小,从nums1后面开始往前进行填充,具体代码如下:

代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
void merge(int* nums1, int nums1Size, int m, int* nums2, int nums2Size, int n)
{

int k = m + n - 1;
int i = m - 1, j = n - 1;
while(i >= 0 && j >= 0)
{
if(nums1[i] > nums2[j])
{
nums1[k--] = nums1[i--];
}
else
nums1[k--] = nums2[j--];
}

if(j >= 0)
{
while(j >= 0)
nums1[k--] = nums2[j--];
}

}