目录
题目链接:88. 合并两个有序数组 - 力扣(LeetCode)
分析:典型归并问题,运用归并思想
思路1:一次归并排序即可
时间O(n+m),空间O(n)
定义新数组arr,长度为m+n(C语言的话看题目定义合适长度)
题目对应的具体实现代码:
int arr[200]={0};
int a = 0; // 新数组记录下标
int n1 = 0, n2 = 0; // 原数组记录下标
while (n1 < m && n2 < n)
{
arr[a++] = nums1[n1] <= nums2[n2] ? nums1[n1++] : nums2[n2++]; //比较 较小值
}
// 剩余数输入(两个循环只会进入一个)
while (n1 < m)
{
arr[a++] = nums1[n1++];
}
while (n2 < n)
{
arr[a++] = nums2[n2++];
}
// 拷贝回nums1数组
for (int i = 0; i < m+n; i++)
{
nums1[i] = arr[i];
}
思路2:双指针比较
时间O(n+m),空间O(1)
题目对应的具体实现代码:
int size = m + n - 1; // nums1的最大下标
int end1 = m - 1, end2 = n - 1; // end1:nums1元素最大下标,end2:nums2元素最大下标
while (end1 >= 0 && end2 >= 0)
{
if (nums1[end1] < nums2[end2])
nums1[size--] = nums2[end2--];
else
nums1[size--] = nums1[end1--];
}
while (end2 >= 0)
{
nums1[size--] = nums2[end2--];
}
以上是我的一点拙见,主要用于开拓自己的思维和记录题解,若有纰漏,还请读者大佬指点