前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >力扣88.合并两个有序数组【顺序表】

力扣88.合并两个有序数组【顺序表】

作者头像
阿伟@t
发布2023-10-10 15:23:00
1540
发布2023-10-10 15:23:00
举报
文章被收录于专栏:cs阿伟cs阿伟

前言:

适合学习了数据结构顺序表后做,此题虽然简单,但是必须结合画图进行分析,同时要仔细阅读题目。

题目要求:


题目分析:

思路:

但是题目中并没有让我们合并到新数组中,而是要求合并到nums1中,题目中已经将空间开好

思路2:采用三指针,i1和i2从后往前进行比较,例如开始时:

i1指向nums1中的3,i2指向nums2末尾的6,j指向nums1末尾的0;

3<6,将i2指向的值给了j,然后i2–,j–;

i1暂时不需要向前偏移,将继续和i2指向的下一个位置进行比较

如上图,我们采取,指针从后逐渐向前偏移的方式,使得nums2从后往前放到nums1后面,但是通过画图,我们发现会出现两种情况:

1.当i2先走完,这时nums1中的元素就是合并后的结果。

2.当i1先走完,这时,需要将nums2中剩余的值放到nums1中,此时的nums1才是最后的结果。

最终代码:

代码语言:javascript
复制
void merge(int* nums1, int nums1Size, int m, int* nums2, int nums2Size, int n)
{
    int i1 = m-1,i2 = n-1;
    int j = m+n-1;
    while(i1 >= 0 && i2 >=0)//不满足一个条件就结束
    {
        if(nums1[i1] > nums2[i2])
        {
            nums1[j--] = nums1[i1--];
            //相当于
            //nums1[j] = nums1[i1];
            //j--;
            //i1--;
        } 
        else
        {
            nums1[j--] = nums2[i2--];
        }
    }
    while(i2 >=0)//当i1走完,i2未走完
    {
        nums1[j--] = nums2[i2--];
    }
}

结语:

这里本章内容就介绍完了,文章中某些内容我们之前有介绍,所以只是一笔带过,还请谅解。

希望以上内容对大家有所帮助👀,如有不足望指出🙏

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2023-10-10,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目要求:
  • 题目分析:
  • 最终代码:
  • 结语:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档