88. 合并两个有序数组

目录

思路1:一次归并排序即可

思路2:双指针比较


题目链接: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--];
}

以上是我的一点拙见,主要用于开拓自己的思维和记录题解,若有纰漏,还请读者大佬指点

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值