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

数据结构-合并两个有效数组

题目描述

给你两个按 非递减顺序 排列的整数数组 nums1 和 nums2,另有两个整数 m 和 n ,分别表示 nums1 和 nums2 中的元素数目。

请你 合并 nums2 到 nums1 中,使合并后的数组同样按 非递减顺序 排列。

注意:最终,合并后数组不应由函数返回,而是存储在数组 nums1 中。为了应对这种情况,nums1 的初始长度为 m + n,其中前 m 个元素表示应合并的元素,后 n 个元素为 0 ,应忽略。nums2 的长度为 n 。

示例 1:

输入:nums1 = [1,2,3,0,0,0], m = 3, nums2 = [2,5,6], n = 3
输出:[1,2,2,3,5,6]
解释:需要合并 [1,2,3] 和 [2,5,6] 。
合并结果是 [1,2,2,3,5,6] ,其中斜体加粗标注的为 nums1 中的元素。

示例 2:

输入:nums1 = [1], m = 1, nums2 = [], n = 0
输出:[1]
解释:需要合并 [1] 和 [] 。
合并结果是 [1] 。

示例 3:

输入:nums1 = [0], m = 0, nums2 = [1], n = 1
输出:[1]
解释:需要合并的数组是 [] 和 [1] 。
合并结果是 [1] 。
注意,因为 m = 0 ,所以 nums1 中没有元素。nums1 中仅存的 0 仅仅是为了确保合并结果可以顺利存放到 nums1 中。

提示:

  • nums1.length == m + n
  • nums2.length == n
  • 0 <= m, n <= 200
  • 1 <= m + n <= 200
  • -109 <= nums1[i], nums2[j] <= 109

进阶:你可以设计实现一个时间复杂度为 O(m + n) 的算法解决此问题吗?

合并两个有序数组

图解

也就是num1的长度是可以满足num2放到里面去的

合并之后变成(按照顺序进行排序)

思路1把数值放到1里面,然后按照排序算法进行排序

思路2,一开始就进行排序好

l1,l2进行排序

然后从后往前进行比较

l1,l2进行比较,每次谁大,谁放到 l3 里面,

l2放到 l3 之后,放完了,l1和l3进行比较

当l3小于0的时候,跳出循环,不进行比较

举例2

代码的实现

while大于0,这里写错了

代码

 这里依旧是,l1,l2,l3是下标,mn是实际的几个数值,所以需要-1

只要l1和l2有一个循环结束,那么就可以跳出循环,

上面的循环是从后往前进行覆盖,这样不会出现覆盖数值的情况,然后进行--

后面我们又给一个循环,因为可能存在一种情况就是这样的情况

这样的情况会产生的结果就是,开始就是num1的空间是够的,但是里面没有数值,直接跳出循环了,所以我们再在下面给出循环判断,要是l2还是大等0的情况下,就是数值还没有完全替换,那么进行赋值 ,赋值到num1的【l3】的下标里面(从后往前进行覆盖)

最后进行--

void merge(int* nums1, int nums1Size, int m, int* nums2, int nums2Size, int n) 
{//这里代表的是下标//l1是nums的实际长度,l2代表的是nums2的实际长度//l3代表的是实际的空间的大小int l1=m-1;int l2=n-1;int l3=m+n-1;while(l1>=0 && l2>=0){if(nums1[l1]>nums2[l2]){nums1[l3--]=nums1[l1--];}else{nums1[l3--]=nums2[l2--];}}while(l2>=0){nums1[l3--]=nums2[l2--];}}

 

http://www.lryc.cn/news/336120.html

相关文章:

  • 华为2024年校招实习硬件-结构工程师机试题(四套)
  • 使用Pandas解决问题:对比两列数据取最大值的五种方法
  • rk3588 安卓13 应用安装黑名单的接口
  • Grafana数据库为MySQL
  • 【计算机考研】数据结构都不会,没有思路,怎么办?
  • word文档显示异常,mac安装word字体:仿宋gb2312
  • 【运维】Ubuntu 配置DNS服务器
  • 头歌-机器学习实验 第8次实验 决策树
  • Spring和Spring MVC和MyBatis面试题
  • 用vue3写一个AI聊天室
  • photomaker:customizing realistic human photos via stacked id embedding
  • FFmpeg - 如何在Linux上安装支持CUDA的FFmpeg
  • 新火种AI|商汤发布下棋机器人元萝卜,率先深入家庭场景。
  • CSS实现三栏自适应布局(两边固定,中间自适应)
  • MoCo 算法阅读记录
  • 华为OD机试 - 数组连续和 - 滑动窗口(Java 2024 C卷 100分)
  • 微店micro获得微店micro商品详情,API接口封装系列
  • C语言中的数据结构--链表的应用1(2)
  • .Net6 使用Autofac进行依赖注入
  • 第十二届蓝桥杯省赛真题(C/C++大学B组)
  • DC40V降压恒压芯片H4120 40V转5V 3A 40V降压12V 车充降压恒压控制器
  • 2、Qt UI控件 -- qucsdk项目使用
  • MATLAB算法实战应用案例精讲-【人工智能】AIGC概念三部曲(三)
  • 外汇110:外汇交易不同货币类别及交易注意事项!
  • gerrit 拉取失败
  • 大数据行业英语单词巩固20240410
  • 天软特色因子看板 (2024.4 第3期)
  • 使用QT 开发不规则窗体
  • 如何构建企业经营所需的商业智能(BI)能力
  • 【vue】watch监听取不到this指向的数?