当前位置: 首页 > article >正文

【C++刷题】力扣-#88-合并两个有序数组

题目描述

给定两个有序整数数组 nums1 和 nums2,其中 nums1 的长度为 m,nums2 的长度为 n。假设 nums1 的大小等于 m + n(即 nums1 有足够的空间存放 nums2 的元素)。你需要将 nums2 合并到 nums1 中,使合并后的数组仍然有序。

示例

示例 1

输入:
nums1 = [1,2,3,0,0,0], m = 3
nums2 = [2,5,6],       n = 3
输出: [1,2,2,3,5,6]
解释: 合并后的数组已按非递减顺序排序。

示例 2

输入:
nums1 = [4,5,6,0,0,0], m = 3
nums2 = [1,2,3],       n = 3
输出: [1,2,3,4,5,6]
解释: 合并后的数组已按非递减顺序排序。

题解

这个问题可以通过双指针法来解决。我们从两个数组的末尾开始,比较并移动较大的元素到 nums1 的末尾。

  1. 初始化指针:设置两个指针 p1 和 p2 分别指向 nums1 和 nums2 的末尾元素。
  2. 从后向前合并:从 nums1 的末尾开始,比较 nums1[p1-1] 和 nums2[p2-1],将较大的元素移动到 nums1 的末尾,并更新指针。
  3. 处理剩余元素:如果 nums2 中还有剩余元素,直接将它们复制到 nums1 的前面。

代码实现

void merge(vector<int>& nums1, int m, vector<int>& nums2, int n) {
    int p1 = m - 1;
    int p2 = n - 1;
    int p = m + n - 1; // nums1 的末尾位置
    
    while (p1 >= 0 && p2 >= 0) {
        if (nums1[p1] > nums2[p2]) {
            nums1[p--] = nums1[p1--];
        } else {
            nums1[p--] = nums2[p2--];
        }
    }
    
    while (p2 >= 0) {
        nums1[p--] = nums2[p2--];
    }
}

复杂度分析

● 时间复杂度:O(m + n),其中 m 和 n 分别是 nums1 和 nums2 的长度。我们需要遍历两个数组。
● 空间复杂度:O(1),因为我们是在原地修改 nums1,没有使用额外的空间。
这个算法的优势在于它直接在 nums1 上进行操作,不需要额外的数组空间。


http://www.kler.cn/news/357060.html

相关文章:

  • 光盘刻录大文件时分卷操作
  • C#中反射基础与应用
  • vueuse的常用方法记录
  • AI 视频工具合集
  • Python无监督学习中的聚类:K均值与层次聚类实现详解
  • 1.Node.js环境搭建(windows)
  • Python基础:20、Python基础综合案例
  • 如何使用python网络爬虫批量获取公共资源数据?
  • 六、存储过程和触发器及视图和临时表
  • 低代码模式即将下线;工作流上线消息节点、支持配置卡片样式
  • 计算机组成原理之磁盘存储器
  • 【分布式微服务云原生】《Redis 的高效之道:线程模型、IO 模型与 Reactor 模型全解析》
  • VB.NET 让窗体绘图持久化,类似VB6 ME.AutoRedraw=True
  • 2.5 windows xp,ReactOS系统快速系统调用的实现
  • 【Linux】冯诺依曼体系结构 OS的概念
  • 图论|图的构造、图的遍历方式、DFS98. 所有可达路径;海岛数量 岛屿最大面积 101. 孤岛的总面积
  • 引进Menu菜单与新增验证上传图片功能--系统篇
  • 编写一个通用的i2c控制器驱动框架
  • Xcode使用Instruments的dsym还原符号堆栈问题
  • 智慧农业案例 (三)- 蔬菜智能温室