博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【LeetCode】Merge Sorted Array(合并两个有序数组)
阅读量:5152 次
发布时间:2019-06-13

本文共 950 字,大约阅读时间需要 3 分钟。

这道题是LeetCode里的第88道题。

题目描述:

给定两个有序整数数组 nums1 和 nums2,将 nums2 合并到 nums1 使得 num1 成为一个有序数组。

说明:

  • 初始化 nums1 和 nums2 的元素数量分别为 m 和 n
  • 你可以假设 nums1 有足够的空间(空间大小大于或等于 m + n)来保存 nums2 中的元素。

示例:

输入:nums1 = [1,2,3,0,0,0], m = 3nums2 = [2,5,6],       n = 3输出: [1,2,2,3,5,6]

从后往前,逐一比较 nums1[i] 和 nums2[j] 的大小。

解题代码:

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

提交结果:

个人总结:

从前往后相对于从后往前花的时间多一些。

转载于:https://www.cnblogs.com/1000sakura/p/10743264.html

你可能感兴趣的文章
iView Card 图文组件
查看>>
C# 反射 名称不区分大小写
查看>>
delphi 控件圆角
查看>>
Java内存缓存
查看>>
Floyd算法(1)
查看>>
问题:python3 使用beautifulSoup时,出错UnicodeDecodeError: 'gbk' codec …….
查看>>
Windows Server 2003 不支持.net framework 4.5
查看>>
H3C 递归查询
查看>>
MapReduce数据流-Reduce
查看>>
linux alloc_pages 接口
查看>>
listen - listen for connections on a socket 在一个套接字上倾听连接
查看>>
linux系统命令配置文件
查看>>
基于docker的mysql主从复制
查看>>
iOS 递归锁
查看>>
IOS之动画
查看>>
springmvc 常用注解
查看>>
orcale 操作练习 Part 1
查看>>
怎样开始冥想
查看>>
spring+mybatis事务的readonly属性无效
查看>>
dubbo学习笔记
查看>>