day19-归并两个有序数组

问题描述:

给你两个按 非递减顺序 排列的整数数组 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 中。

解决方案:

1、有序数组中,引入三个指针:

        (1)指向 num_1[ ] 中最后有效数字,即num_1[ m-1 ]

        (2)指向 num_2[ ] 中末尾数字,即num_2[ n-1 ]

        (3)指向 num_1[ ] 中末尾位置,即num_1[ m+n-1 ]

2、比较(1)与(2)中的数字大小,较大者复制进入(3)位置,再依次向前比较

3、特例:

        一:(1)中的元素已经比较完毕,但是(2)中依然存在元素,则把(2)中的元素直接复制加入到(3)中即可。

        二:(2)中没有元素可比较而(1)内还有元素,则可不做处理:因为(3)与(1)是在同一数组内。

函数代码:

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

优化方案:

1、m--,n--,i--:等效于:i-=1,但是 返回值为 原值,存在语句执行的优先级,即先使用 m,n,i 原值,待该语句执行完毕后再进行自减(i--)或自增操作(i++)

2、--i,--m,++n:等效于:i-=1,但是返回值为 原值 - 1,语句优先级:先减 先减 再使用,即该语句使用的是原值自减后的值(i-1)

优化代码: 

class Solution {
public:void merge(vector<int>& nums1, int m, vector<int>& nums2, int n) {int i=(m--)+(n--)-1;while(  n>=0 && m>=0 )nums1[i--] = (nums1[m] < nums2[n])? nums2[n--]:nums1[m--];while(n>=0)nums1[i--]=nums2[n--];}
};

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

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

相关文章

Qt5.15以上版本在线安装步骤,可选择更多早期版本

以ubuntu系统为例&#xff1a; 1、先去下载在线安装程序&#xff1a; https://download.qt.io/official_releases/online_installers/ 选择合适的版本&#xff0c;这里是在x64机器的ubuntu虚拟机里安装QT&#xff0c;所以选择如下版本&#xff1a; 或者直接在终端执行如下命令…

Qt | 元对象系统

一、QByteArray 类简介 1、QByteArray 类简介  该类是一个用于处理字符串的类似于 C++的 string 类型的类,在 Qt 中,对字符串的处理,经常使用的是 QString 类,该类保证字符串以\0结尾,并使用隐式共享(copy-on-write)来减少内存用量和不必要的数据复制。  QByteArra…

【ControlNet v3版本论文阅读】

网络部分最好有LDM或者Stable Diffusion的基础&#xff0c;有基础的话会看的很轻松 Abstract 1.提出了一种网络结构支持额外输入条件控制大型预训练的扩散模型。利用预训练模型学习一组不同的条件控制。 2.ControlNet对于小型&#xff08;<50k&#xff09;或大型&#xff…

Halcon的HWindowControl控件在C#WinForm中的使用介绍(包括绘制ROI)

Halcon的HSmartWindowControl控件在C#WinForm中的使用介绍&#xff08;包括绘制ROI&#xff09; 文章目录 Halcon的HSmartWindowControl控件在C#WinForm中的使用介绍&#xff08;包括绘制ROI&#xff09;一、 引入hSmartWindowControl控件二、 编写打开图像功能三、 编写绘制RO…

如何保护您的企业免受人工智能生成的深度伪造品的侵害

最近&#xff0c;网络犯罪分子利用一家跨国公司高管的“深度伪造”视频&#xff0c;说服该公司驻香港的员工汇出 2560 万美元。 根据包含多个 Deepfake 的视频电话会议&#xff0c;员工认为是他们驻英国的首席财务官要求转移资金。 据报道&#xff0c;警方已逮捕六名与该诈骗案…

操作系统②——内存管理

1. 栈、堆 1.1 程序的内存分配 栈区&#xff08;stack&#xff09;&#xff1a;由编译器自动分配释放 &#xff0c;存放函数的参数值&#xff0c;局部变量的值等。其操作方式类似于数据结构中的栈。堆区&#xff08;heap&#xff09;&#xff1a;一般由程序员分配释放&#x…

光猫桥接模式详细步骤

目录 一、前言 路由模式 &#xff08;宽带默认&#xff09; 桥接模式 二、桥接模式步骤 &#xff08;一&#xff09;图片记录备份 设备信息图 网络侧信息 远程管理密码 宽带上网设置 &#xff08;二&#xff09;桥接模式开始 光猫设置 路由器设置 一、前言 重点&a…

jQuery的链式编程

在jQuery中&#xff0c;如果一直对同一个元素进行函数操作&#xff0c;那么可以使用 函数操作名&#xff0c;一直写下去。 //这是普通的事件绑定$("button").click(function() {console.log("1")})$("button").mouseenter(function() {console.l…

存内计算技术在边缘计算、物联网设备中的应用及前景

存内计算技术简介 存内计算技术是一种新兴的计算范式&#xff0c;其核心理念是将存储和计算功能集成在同一硬件单元中。这种技术的优势在于能够在存储单元内部直接进行计算操作&#xff0c;从而减少数据在存储器和处理器之间的传输&#xff0c;提高计算效率。 以下是存内计算技…

2024-04-02 问AI:介绍一下深度学习中的 “迁移学习”

文心一言 迁移学习&#xff08;Transfer Learning&#xff09;是深度学习中一种重要的机器学习方法&#xff0c;其核心思想是将为某个任务A开发的模型作为初始点&#xff0c;重新使用在为任务B开发模型的过程中。这种方法的目的是通过从已学习的相关任务中转移知识&#xff0c…

2_5.Linux存储的基本管理

实验环境&#xff1a; 系统里添加两块硬盘 ##1.设备识别## 设备接入系统后都是以文件的形式存在 设备文件名称&#xff1a; SATA/SAS/USB /dev/sda,/dev/sdb ##s SATA, dDISK a第几块 IDE /dev/hd0,/dev/hd1 ##h hard VIRTIO-BLOCK /de…

sharding‐jdbc之分库分表(mysql主从同步的数据库安装和使用)

水平分表 创建基础工程.. 引入sharding‐jdbc的maven依赖包 注意需要数据库连接池等依赖 <dependency><groupId>org.apache.shardingsphere</groupId><artifactId>sharding-jdbc-spring-boot-starter</artifactId><version>4.0.0-RC1&l…

【JavaWeb】Day36.MySQL概述——数据库设计-DDL(三)

查询 关于表结构的查询操作&#xff0c;工作中一般都是直接基于图形化界面操作。 1.查询当前数据库所有表 2.查看指定表结构 3.查询指定表的建表语句 注意&#xff1a;23版的点击导航中的转到DDL 修改 关于表结构的修改操作&#xff0c;一般也是直接基于图形化界面操作。 添…

智能感应门改造工程

今天记录一下物联网专业学的工程步骤及实施过程 智能感应门改造工程 1 规划设计1.1 项目设备清单1.2项目接线图 软件设计信号流 设备安装与调试工程函数 验收 1 规划设计 1.1 项目设备清单 1.2项目接线图 软件设计 信号流 设备安装与调试 工程函数 工程界面: using System; …

半导体runcard(上)--基础知识精讲

半导体runcard是指在半导体制造过程中&#xff0c;用于记录和管理生产过程中的关键参数和数据的一种系统或方法。runcard可以是纸质的记录方式&#xff0c;也可以是电子化的管理系统。在半导体行业中&#xff0c;runcard的使用非常广泛&#xff0c;它涉及到从原材料检验、晶圆加…

【STM32】存储器和位带映射(bit band mapping)

文章目录 0 前言1 关于地址和存储器2 STM32内部存储器3 位带映射&#xff08;bit band mapping&#xff09;4 扩展&#xff1a;IAP 0 前言 最近在研究stm32标准库&#xff0c;对使用宏定义实现位操作的函数非常感兴趣&#xff0c;简单的一句PAout(1) 0;就能实现某个引脚电平的…

bash简化if-else

#!/usr/bin/env bashsource /bal/bash-simplify/dir_util.sh#测试_get_arg: #debug__get_argtrue; x$(_get_arg example.sh 37 "true ||") ; echo $x #_is_git_2xfunction _get_arg(){ ##若变量debug__get_arg为空&#xff0c;则设置其为false # [ "x" &…

Linux离线安装python3(源码编译)

1、下载python包 下载python3.9.6的源码包 python下载 下载后&#xff0c;解压&#xff0c;目录如下&#xff1a; -rw-------. 1 root root 1454 Aug 26 2023 anaconda-ks.cfg -rw-r--r--. 1 root root 25640094 Apr 4 21:52 Python-3.9.6.tgz drwxrwxr…

LeetCode 1049. 最后一块石头的重量 II

有一堆石头&#xff0c;用整数数组 stones 表示。其中 stones[i] 表示第 i 块石头的重量。 每一回合&#xff0c;从中选出任意两块石头&#xff0c;然后将它们一起粉碎。假设石头的重量分别为 x 和 y&#xff0c;且 x < y。那么粉碎的可能结果如下&#xff1a; 如果 x y&…

C# 访问修饰符 默认

命名空间下的元素&#xff1a;类&#xff08;Class&#xff09;中的成员&#xff1a;结构&#xff08;Struct&#xff09;中的成员&#xff1a;接口&#xff08;Interface&#xff09;中的成员&#xff1a;接口&#xff08;Interface&#xff09;本身&#xff1a;枚举&#xff…