【LeetCode】88. Merge Sorted Array 解题报告(Java & Python)
2024-09-02 15:36:24
作者: 负雪明烛
id: fuxuemingzhu
个人博客: http://fuxuemingzhu.cn/
题目地址:https://leetcode.com/problems/merge-sorted-array/description/
题目描述
Given two sorted integer arrays nums1 and nums2, merge nums2 into nums1 as one sorted array.
Note:
- The number of elements initialized in nums1 and nums2 are m and n respectively.
- You may assume that nums1 has enough space (size that is greater or equal to m + n) to hold additional elements from nums2.
Example:
Input:
nums1 = [1,2,3,0,0,0], m = 3
nums2 = [2,5,6], n = 3
Output: [1,2,2,3,5,6]
题目大意
把两个有序的数组合并,把结果放到nums1中去。
解题方法
这个题的核心是注意到两个数组是已经有序的!这样就可以很简单的解决。
方法是在每个数组的最后一个指定位置判断大小,根据判定的大小放到nums1的最后位置里,然后移动指针,继续判断,直到一个数组先遍历结束。
注意,如果nums1已经遍历结束了,就要把nums2剩下的元素放到nums1的前面。最后可以确保有序。
另外,我以后可能就使用python刷题了,虽然语言大同小异,最主要的还是锻炼自己的语言基础。这个题中函数不用返回。
class Solution(object):
def merge(self, nums1, m, nums2, n):
"""
:type nums1: List[int]
:type m: int
:type nums2: List[int]
:type n: int
:rtype: void Do not return anything, modify nums1 in-place instead.
"""
while m > 0 and n > 0:
if nums1[m - 1] > nums2[n -1]:
nums1[m + n - 1] = nums1[m - 1]
m -= 1
else:
nums1[m + n - 1] = nums2[n - 1]
n -= 1
nums1[:n] = nums2[:n]
二刷的版本:
class Solution(object):
def merge(self, nums1, m, nums2, n):
"""
:type nums1: List[int]
:type m: int
:type nums2: List[int]
:type n: int
:rtype: void Do not return anything, modify nums1 in-place instead.
"""
i, j = m - 1, n - 1
k = m + n - 1
while i >= 0 and j >= 0:
if nums1[i] > nums2[j]:
nums1[k] = nums1[i]
i -= 1
else:
nums1[k] = nums2[j]
j -= 1
k -= 1
while j >= 0:
nums1[k] = nums2[j]
j -= 1
k -= 1
新建数组
新建一个数组,保存结果,然后把排序了的结果放入到nums1中就好了。
class Solution(object):
def merge(self, nums1, m, nums2, n):
"""
:type nums1: List[int]
:type m: int
:type nums2: List[int]
:type n: int
:rtype: void Do not return anything, modify nums1 in-place instead.
"""
nums = [n1 for i, n1 in enumerate(nums1) if i < m] + [n2 for i, n2 in enumerate(nums2) if i < n]
nums.sort()
for i, num in enumerate(nums):
nums1[i] = num
日期
2017 年 8 月 21 日
2018 年 11 月 24 日 —— 周六快乐
最新文章
- 轻松搞定Win8 IIS支持SVC 从而实现IIS寄宿WCF服务
- Yeoman
- C#实现Comparable接口实现排序
- 第十三章、学习 Shell Scripts 循环 (loop)
- Linux 硬连接和软连接的原理 (in使用)
- –save与–save-dev
- web.xml的配置问题
- jquery 设置select的默认值
- Jquery--仿制360右下角弹出窗口
- ES踩坑笔记
- 2018年12月8日广州.NET微软技术俱乐部活动总结
- python模块shutil
- activate-power-mode 插件 安装 设置 IDEA
- Effective Java 第三版——58. for-each循环优于传统for循环
- 常用Build-in Keywords
- sass问题
- php中一些常用的语句收集
- Java中的String和StringBuffer
- c#(winform)环境下使用动态链接库dll的详解
- 使用TimeSpan对象获取时间间隔
热门文章
- R shinydashboard——3.外观
- 爬虫动态渲染页面爬取之selenium驱动chrome浏览器的使用
- Django向数据库批量插入数据
- bwa比对软件的使用以及其结果文件(sam)格式说明
- 通用的js异步ajax文件上传函数
- [转] Java中对数据进行加密的几种方法
- Can references refer to invalid location in C++?
- keepalived 高可用lvs的dr模型(vip与dip不在同一网段)
- C语言编辑链接
- &#127942;【Alibaba中间件技术系列】「RocketMQ技术专题」Broker配置介绍及发送流程、异常(XX Busy)问题分析