Leetcode刷题之合并两个有序数组

Leetcode刷题之合并两个有序数组

  • 一、题目描述
  • 二、题目解析

一、题目描述

给你两个按 非递减顺序 排列的整数数组 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和nums2。nums1和nums2是两个严格非递减的有序数组(也就是说除了递增,还有相等的情况)。我们需要将这两个数组合并成为一个新的数组,并将新的数组存放nums1数组当中。
在这里插入图片描述
那么我们如何进行合并操作呢?我们可以首先在每一个数组的元素末端位置,分别定义两个变量,取名叫end1和end2。并且在nums1数组的最后一个位置再次定义一个i变量。在这里插入图片描述
之后我们开始移动数据的位置。如果说,end2位置的数据大于end1数据位置的值时,我们将end2位置的值赋给数组nums1数组的i位置。并且让i和end2同时进行- -操作。反之则让end1位置的值赋给i,并且两个变量同时减减操作。当end2先减减到小于,这是第一种情况。因为nums1的元素被本身就存放在nums1数组中,并且元素本身就存在顺序,所以不用管。
第二种情况,就是end2数组中还有剩余元素,那么我们仅仅需要将其他元素继续放在i位置即可。如下图这种情况:
在这里插入图片描述
代码如下:

void merge(int* nums1, int nums1Size, int m, int* nums2, int nums2Size, int n){int end1=m-1;int end2=n-1;int i=m+n-1;while(end1>=0&&end2>=0){if(nums1[end1]<nums2[end2]){nums1[i]=nums2[end2];i--;end2--;}else{nums1[i]=nums1[end1];i--;end1--;        }}    while(end2>=0){nums1[i]=nums2[end2];i--;end2--;}
}

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/823268.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

P1101 单词方阵

# 单词方阵 ## 题目描述 给一 n*n的字母方阵,内可能蕴含多个 `yizhong` 单词。单词在方阵中是沿着同一方向连续摆放的。摆放可沿着 8个方向的任一方向,同一单词摆放时不再改变方向,单词与单词之间可以交叉,因此有可能共用字母。输出时,将不是单词的字母用 `*` 代替,以突…

MongoDB快速启动

两种方法: 方式 1 &#xff1a;命令行参数方式启动服务 在 bin 目录中打开命令行提示符&#xff0c;输入如下命令&#xff1a; (mongod --dbpath..\data\db) mongod --dbpath..\data\db 方式 2 &#xff1a;配置文件方式启动服务 在解压目录中新建 config 文件夹&#xff0…

去哪网拿去花不能提现,只能用于透支消费,那么拿去花提现是怎么实现呢?

去哪网拿去花不能提现&#xff0c;只能用于透支消费&#xff0c;那么拿去花提现是怎么实现呢&#xff1f; 申请携程拿去花之后&#xff0c;有一些人就会想着把钱提现出来拿去用。一般来说&#xff0c;他们都是通过线下门店来提现拿去花&#xff0c;拿去花允许用户先消费后付款&…

财富是对认知的奖赏,不是勤劳的补偿,那怎么提升认知呐?

在经济学著作《贫穷的本质》中&#xff0c;作者阿比吉特班纳吉和埃斯特迪弗洛通过深入调查和研究&#xff0c;揭示了贫穷的多重面貌&#xff0c;并探讨了穷人为何难以摆脱贫困的困境。这本书的核心观点之一是&#xff0c;贫穷并非仅仅由缺乏勤劳造成&#xff0c;而是与个人和群…

「2024前端」常见面试题之JavaScript

1. 原型链和原型链的继承&#xff0c;前端的继承方式有哪些&#xff1f; 原型链和原型链的继承 在JavaScript中&#xff0c;原型链是实现继承的一种机制。每一个对象都有一个原型对象&#xff0c;从原型对象继承方法和属性。这些对象可以作为其他对象的原型&#xff0c;形成一…

Python文件操作大全

1 文件操作 1.1 文件打开与关闭 1.1.1 打开文件 在Python中&#xff0c;你可以使用 open() 函数来打开文件。以下是一个简单的例子&#xff1a; # 打开文件&#xff08;默认为只读模式&#xff09; file_path example.txt with open(file_path, r) as file:# 执行文件操作…

LeetCode-二叉树修剪

每日一题 今天遇到的题比较简单&#xff0c;是一道二叉树的题。 题目要求 给定一个二叉树 根节点 root &#xff0c;树的每个节点的值要么是 0&#xff0c;要么是 1。请剪除该二叉树中所有节点的值为 0 的子树。 节点 node 的子树为 node 本身&#xff0c;以及所有 node 的…

ARM-学习day8

使用温湿度采集&#xff0c;控制灯&#xff0c;风扇和马达. lic.h #ifndef __IIC_H__ #define __IIC_H__#include"stm32mp1xx_gpio.h" #include"stm32mp1xx_rcc.h"#define SET_SDA_OUT do{GPIOF->MODER & (~(0x3 << 30)); \GPIOF->M…

6. Mysql里面的GTID 全局事务标识 介绍

GTID学习记录 来源 知乎阿里云&#xff1a;MySQL 基于GTID复制实现的工作原理MySQL的GTID主从搭建及内部原理MySQL5.7杀手级新特性&#xff1a;GTID原理与实战 文章目录 1 什么是GTID2 GTID的组成部分3 GTID如何产生4 GTID的工作原理5 GTID的生成和使用由以下几步组成&#xf…

Linux学习随笔

进程 每个进程都有对应的文件句柄空间&#xff0c;以及一个用户栈和内核栈 冷、热启动 "冷启动"是指将电子设备从完全关机的状态重新启动的过程。在开发板的上下文中&#xff0c;冷启动通常意味着关闭电源然后重新打开&#xff0c;或者通过物理按钮或者开关来触发重…

appium2报错:Failed to create session. ‘automationName‘ can‘t be blank

1、问题概述&#xff1f; 今天在window环境中安装了appium2.5.2版本&#xff0c;通过appium inspector连接真机的时候报错如下&#xff1a; Failed to create session. automationName cant be blank 原因分析&#xff1a;这是因为appium2的比appium1有了很大的改进&#xff…

TCP连接状态如何判断

在嵌入式C语言环境中&#xff0c;当TCP客户端与服务端正常连接并持续发送消息时&#xff0c;若遇到异常情况导致连接断开&#xff0c;可以通过以下几种方法来检测这种异常断开&#xff1a; 1. 使用select()或poll()系统调用&#xff1a; 通过select()或poll()函数可以监控套…

Linux 指令之文件

1.开发背景 记录 linux 下对文件操作的指令 2.开发需求 记录常用的文件操作指令 3.开发环境 linux 操作系统&#xff0c;如果不支持需要查看是否存在对应的可执行文件 4.实现步骤 4.1 查找字符串 查找指定目录下包含指定的字符串 grep -rn "Timer frequency" .…

python中如何求阶乘

第一种、利用functools工具处理 import functools result (lambda k: functools.reduce(int.__mul__, range(1, k 1), 1))(5) print(result)第二种、普通的循环 x 1 y int(input("请输入要计算的数:")) for i in range(1, y 1):x x * i print(x) 第三种、利用…

java web编程技术

前面首先记录一些关键的/重要的/不好记的短语/单词/词汇&#xff0c;之后的之后再说 Browser 浏览器 Server 服务器 client 客户端 服务器编程语言有三种&#xff1a; ASP(Active server page)动态服务器页面 PHP(Personal home page)超文本预处理器 JSP(Java server pa…

什么是世面,是世界的每一面!

什么是世面&#xff1a;探索世界的多维度面貌 我们经常会听到“见世面”这个词汇&#xff0c;它通常用来形容一个人通过广泛的旅行、阅读和社交活动&#xff0c;积累了丰富的知识和经验&#xff0c;从而对世界有了更深刻的理解和认识。但“世面”究竟是什么&#xff1f;它不仅…

美格智能出席紫光展锐第三届泛金融支付生态论坛,引领智慧金融变革向新

4月16日&#xff0c;以“融智创新&#xff0c;共塑支付产业新生态”为主题的紫光展锐第三届泛金融支付生态论坛在福州举办&#xff0c;来自金融服务机构、分析师机构、终端厂商、模组厂商等行业各领域生态伙伴汇聚一堂&#xff0c;探讨金融支付产业的机遇与挑战。作为紫光展锐重…

浮点数的存储方式、bf16和fp16的区别

目录 1. 小数的二进制转换2. 浮点数的二进制转换3. 浮点数的存储3.1 以fp32为例3.2 规约形式与非规约形式 4. 各种类型的浮点数5. BF16和FP16的区别Ref 1. 小数的二进制转换 十进制小数转换成二进制小数采用「乘2取整&#xff0c;顺序排列」法。具体做法是&#xff1a;用 2 2…

数据结构复杂度

算法的时间复杂度 常对幂指阶 小练习1 小练习2

【实战】Dubbo应用可观测性升级指南与踩坑记录

应用从dubbo-3.1.*升级到dubbo-*:3.2.*最新稳定版本&#xff0c;提升dubbo应用的可观测性和度量数据准确性。 1. dubbo版本发布说明(可不关注) dubbo版本发布 https://github.com/apache/dubbo/releases 【升级兼容性】3.1 升级到 3.2 2. 应用修改点 注意&#xff1a;Sprin…