88. 合并两个有序数组(简单)

88. 合并两个有序数组

  • 1. 题目描述
  • 2.详细题解
  • 3.代码实现
    • 3.1 Python
    • 3.2 Java

1. 题目描述

题目中转:88. 合并两个有序数组
在这里插入图片描述
在这里插入图片描述

2.详细题解

    两个数组均有序(非递减),要求合并两个数组,直观的思路,借助第三个数组,依次从左至右遍历两个数组,比较二者大小,将较小的依次放入第三个数组中,遍历完毕后,将第三个数组的元素再依次写入指定的第一个数组。但这样存在的问题是,会有O(m+1)的空间耗费,因此充分利用第一个数组可以优化这部分空间耗费。
  如果两个数组均从左至右遍历,按照非递减顺序合并不借助第三者并不能完成合并,而第一个数组后半部分(n个长度)是闲置的,因此两个数组可以从右至左的顺序遍历,按照非递增的顺序合并,先定位大值元素的位置;此时不用担心第一数组的空余位置不够用,因为后半部分长度为第二个数组的长度,肯定也会有疑问,第一个数组不是也会把数据移入后半部分吗?但忽略了第一个数组每移入一个数据到后半部分,同时也会空出一个位置。
  因此使用两个指针p1和p2,分别指向两个数组中的最后一个元素索引即m-1和n-1,当指针p1指向元素大于等于指针p2指向的元素时,则将指针p1指向的元素移入指定位置并指针向左移动一位(即p1–),否则,将指针p2指向的元素移入指定位置并指针向左移动一位(即p2–);移入的位置也需要定位,因此还需要第三个指针tail,执行第一个数组的末尾即m+n-1,每移入一个元素,则该指针向左移动一位(即tail–)。

3.代码实现

3.1 Python

class Solution:def merge(self, nums1: List[int], m: int, nums2: List[int], n: int) -> None:"""Do not return anything, modify nums1 in-place instead."""p1, p2 = m-1, n-1tail = m + n - 1while p1 >= 0 and p2 >= 0:if nums1[p1] >= nums2[p2]:nums1[tail] = nums1[p1]p1 -= 1else:nums1[tail] = nums2[p2]p2 -= 1tail -= 1if p2 >=0:nums1[:p2+1] = nums2[:p2+1]

在这里插入图片描述

3.2 Java

class Solution {public void merge(int[] nums1, int m, int[] nums2, int n) {int p1 = m - 1;int p2 = n - 1;int tail = m + n - 1;while (p1 >=0 && p2 >= 0){if (nums1[p1] >= nums2[p2]){nums1[tail--] = nums1[p1--];}else{nums1[tail--] = nums2[p2--];}}if (p2 >= 0){for (int i=0;i<=p2;i++){nums1[i] = nums2[i];}}}
}

在这里插入图片描述

  执行用时不必过于纠结,对比可以发现,对于python和java完全相同的编写,java的时间一般是优于python的;至于编写的代码的执行用时击败多少对手,执行用时和网络环境、当前提交代码人数等均有关系,可以尝试完全相同的代码多次执行用时也不是完全相同,只要确保自己代码的算法时间复杂度满足相应要求即可,也可以通过点击分布图查看其它coder的code

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

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

相关文章

【Linux环境下Hadoop部署】—报错“Unit ntpd.service could not be found.“

项目场景&#xff1a; 执行 “systemctl status ntpd” 命令。 问题描述 报错&#xff1a;Unit ntpd.service could not be found. 原因分析&#xff1a; 没有安装ntp 解决方案&#xff1a; 执行 “yum install ntp” 命令&#xff0c;再次执行 “systemctl status ntpd” 命令…

Docker部署私有仓库Harbor

Harbor构建Docker私有仓库 文章目录 Harbor构建Docker私有仓库资源列表一、部署Docker-Compose服务1.1、下载最新Docker-Compose1.2、查看Docker-Compose版本 二、部署Harbor服务2.1、下载Harbor安装程序2.2、配置Harbor参数文件2.3、所需参数和可选参数2.3.1、所需参数2.3.2、…

平庸的学术工作者

自己进入学术这条路&#xff0c;差不多十年了&#xff0c;回想自己目前的成果&#xff0c;自我评价为平庸。如果将同领域清华的年轻学者打分为 100 分的话&#xff0c;我将自己打分 65。 到目前为止&#xff0c;并不觉得智力因素在管理科学与工程领域的科研中有太大决定作用&a…

Demeditec Diagnostics DmbH兽医诊断类科研试剂

此类产品包括用于多种动物物种包括狗(犬)、猫、牛、马、大鼠和小鼠等分析物的检测。 皮质酮酶联免疫检测试剂盒(Corticosterone rat/mouse Elisa Kit) 产品编号&#xff1a;DEV9922 皮质酮是肾上腺皮质在应答促肾上腺皮质激素时所产生的一种糖皮质激素&#xff0c;是醛甾酮前…

CP AUTOSAR标准之MemoryDriver(AUTOSAR_CP_SWS_MemoryDriver)

1 简介和功能概述 该规范描述了AUTOSAR基础软件模块内存驱动程序(Mem)的功能、API和配置。   内存驱动程序提供访问不同类型内存设备的基本服务,如读取、写入、擦除和空白检查。   尽管闪存仍然是最常见的非易失性存储器技术,但内存驱动程序规范考虑了所有相关的内存设备…

SS928的SVP_NNN和NNN的区别

图像分析引擎 2 &#xff08;SVP_NNN&#xff09;与图像分析引擎 1 &#xff08;NNN&#xff09;在多个方面存在差异&#xff0c;以下是一些主要的区别和使用上的差异点&#xff1a; 接口风格差异&#xff1a; 图像分析引擎 1 使用 ACL 接口&#xff0c;而图像分析引擎 2 使用 …

虚拟警示教育馆如何革新安全教育?揭秘其深远意义与实际优势

一、推动警示教育的创新与普及 虚拟警示教育馆是将传统警示教育与现代科技相结合的新型教育模式。其意义主要体现在以下几个方面&#xff1a; 1、增强教育的互动性和沉浸感&#xff1a;虚拟警示教育馆通过3D建模、VR等技术&#xff0c;创建逼真的警示场景。这种身临其境的体验能…

(资料收藏)王阳明传《知行合一》共74讲,王阳明知行合一音频讲解资料

今天给大家带来的不是软件&#xff0c;而是一份精神食粮——《知行合一》的教程福利。这可不是一般的教程&#xff0c;它关乎心灵&#xff0c;关乎智慧&#xff0c;关乎我们如何在纷繁复杂的世界中找到自己的位置。 咱们得聊聊王阳明&#xff0c;这位明代的大儒&#xff0c;他…

餐饮业应该购置精酿啤酒设备吗?

近几年&#xff0c;啤酒行业刮起了一股“精酿风”&#xff0c;它不只是一种饮品口味上的变化&#xff0c;更像是一个生活方式的升级。精酿啤酒的兴起&#xff0c;不仅体现在味道的多样性和层次感上&#xff0c;更重要的是它代表了一种生活态度&#xff0c;是对品质生活的追求。…

可复用验证的测试用例 5大编写技巧

编写可复用验证的测试用例&#xff0c;节省了编写新测试用例的时间和资源&#xff0c;提高了测试效率和项目质量&#xff0c;减少错误修复成本&#xff0c;有利于实现较高的投入产出比。缺乏可复用的测试用例会导致测试团队不断重复创建相似的测试场景&#xff0c;消耗大量时间…

Windows Server 远程桌面显示登录界面而不是直接登录进入的问题

Windows Server 我们通过使用远程桌面客户端软件去登录&#xff0c;通常情况下是在远程桌面客户端里面输入用户名和密码&#xff0c;点【连接】按钮&#xff0c;就直接登录进入远程桌面了。 但是&#xff0c;有时候&#xff0c;不能直接进入&#xff0c;而是远程服务器的登录界…

每日一练:攻防世界:Ditf

这是难度1的题吗&#xff1f;&#xff1f;&#xff1f; 拿到一个png图片&#xff0c;第一反应就是CRC爆破&#xff0c;结果还真的是高度被修改了 这里拿到一个字符串&#xff0c;提交flag结果发现不是&#xff0c;那么只可能是密钥之类的了 看看有没有压缩包&#xff0c;搜索…

IMU应用于体操训练

考虑到在艺术体操训练与竞赛中艺术体操的训练与比赛中&#xff0c;地板项目导致的伤率最高&#xff0c;最近&#xff0c;一个来自澳大利亚的科研团队利用IMU评估运动员执行基础翻腾技巧训练时&#xff0c;他们上肢与下肢所承受的冲击负荷。 本次实验共有十四名艺术体操运动员参…

(五)React受控表单、获取DOM

1. React受控表单 概念&#xff1a;使用React组件的状态&#xff08;useState&#xff09;控制表单的状态 准备一个React状态值 const [value, setValue] useState()通过value属性绑定状态&#xff0c;通过onChange属性绑定状态同步的函数 <input type"text"…

TDengine 签约天合富家,支持百万电站海量数据管理

在全球能源转型和数字化浪潮的双重推动下&#xff0c;天合富家能源股份有限公司凭借其领先的分布式光伏技术和系统解决方案&#xff0c;在分布式能源市场中稳居领先地位。在持续创新的道路上&#xff0c;其面临的一个主要挑战是如何高效处理来自全国各地百万电站的海量数据。 …

计算机网络期末复习1(最后一天才开始学版)

1.一个PPP帧的数据部分&#xff08;用十六进制写出&#xff09;是7D 5E FE 27 7D 5D 7D 5D 65 7D 5E。试问真正的数据是&#xff08;用十六进制写出&#xff09; 由于PPP帧的标志字段为7E,因此,为了区别标志字段和信息字段,将信息字段中出现的每一个0x7E转变成(0x7D,0x5E),0x7…

【文末附gpt升级秘笈】SDCon 2024全球软件研发技术大会:引领AI 2.0时代的软件开发新篇章

SDCon 2024全球软件研发技术大会&#xff1a;引领AI 2.0时代的软件开发新篇章 一、引言 随着人工智能技术的飞速发展&#xff0c;我们迎来了AI 2.0时代。在这个时代&#xff0c;人工智能技术不仅深刻影响着我们的日常生活&#xff0c;更在软件研发领域掀起了一场革命。AI原生…

MVC 应用程序

MVC 应用程序 MVC(Model-View-Controller)是一种广泛使用的软件设计模式,它将应用程序的逻辑、界面和用户交互分离,以提高代码的可维护性和可扩展性。MVC模式最早在20世纪70年代被提出,并随着时间的推移在多种编程语言和框架中得到应用,特别是在Web应用程序开发中。 MV…

基于深度学习的文本翻译

基于深度学习的文本翻译 基于深度学习的文本翻译&#xff0c;通常称为神经机器翻译&#xff08;Neural Machine Translation, NMT&#xff09;&#xff0c;是近年来在自然语言处理&#xff08;NLP&#xff09;领域取得显著进展的技术。NMT通过使用深度神经网络来自动学习和翻译…

PIL保存后的图像莫名的失真,部分不失真部分很失真

原图片是这样的&#xff1a; PIL会自行**“自救”被正则化的图片&#xff0c;导致自救过曝&#xff0c;部分颜色非常失真&#xff0c;但是部分又保存的还行。现象如下&#xff1a; 这里你检查一下你保存的是不是被正则化的图片**&#xff0c;如果是&#xff0c;改改。 查看一…