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

合并两个有序数组-力扣88-java

一、题目描述

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

来源:力扣(LeetCode)

链接:https://leetcode.cn/problems/merge-sorted-array

著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

二、运行结果

三、解题思路

首先对两种特殊情况做处理:如果nums为空,则直接返回,不用合并,如果nums1中要合并的个数为0,则直接将nums2复制到nums1中返回;

从nums1和nums2中需要合并的最后一个元素开始往前遍历,将nums1和nums2当前较大的元素放到nums1的末尾(逐渐向前面放)。如果nums2中的元素已经被合并完,则返回,如果nums1中的元素已经被合并完,则将nums2中剩余的元素直接复制到nums1的最前面即可。

四、AC代码

class Solution {public void merge(int[] nums1, int m, int[] nums2, int n) {if(n == 0) return;if(m == 0) {for(int i=0; i<n; i++) //将nums2复制到nums1中nums1[i] = nums2[i];return;}int p1 = m-1, p2 = n-1;for(int i=m+n-1; i>=0; i--){ if(p2 < 0)break;if(p1 >= 0 && nums1[p1] >= nums2[p2]){ //如果p1<0,则会跳转到else执行nums1[i] = nums1[p1];p1--;}else{nums1[i] = nums2[p2];p2--;}}}
}
http://www.lryc.cn/news/9429.html

相关文章:

  • 2022「大厂可观测」重磅回顾,12场直播,15位技术大咖洞见可观测
  • CMMI-配置管理(CM)
  • 网络编程套接字Socket
  • Linux进程概念(二)
  • 墨天轮【第二届数据库掌门人论坛】圆满收官 | 含嘉宾精彩观点回顾
  • Redis之集群搭建
  • 31-Golang中的二维数组
  • <<Java开发环境配置>>6-SQLyog安装教程
  • MySQL 中的 distinct 和 group by 哪个效率更高
  • 计算机相关专业毕业论文选题推荐
  • 网络编程套接字之TCP
  • 网络与串口调试工具TCPCOM
  • 数据库常用命令
  • PTA复习
  • TypeScript 学习之接口
  • 原码反码补码
  • 大数据选股智能推荐系统V1.0-1
  • 调研生成GIF表情包之路
  • 【RocketMQ】源码详解:生产者启动与消息发送流程
  • 信息安全(一)
  • 企业多会场视频直播(主会场、分会场直播)实例效果
  • 线性代数速览(一)行列式
  • 恭喜山东翰林“智慧园区管理系统”获易知微可视化设计大赛二等奖
  • gulp简单使用
  • ce认证机构如何选择?
  • 全网招募P图高手!阿里巴巴持续训练鉴假AI
  • webrtc QOS笔记一 Neteq直方图算法浅读
  • 细分和切入点
  • iOS创建Universal Link
  • RuoYi-Vue搭建(若依)