作者: 负雪明烛
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:

  1. The number of elements initialized in nums1 and nums2 are m and n respectively.
  2. 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 日 —— 周六快乐

最新文章

  1. 轻松搞定Win8 IIS支持SVC 从而实现IIS寄宿WCF服务
  2. Yeoman
  3. C#实现Comparable接口实现排序
  4. 第十三章、学习 Shell Scripts 循环 (loop)
  5. Linux 硬连接和软连接的原理 (in使用)
  6. –save与–save-dev
  7. web.xml的配置问题
  8. jquery 设置select的默认值
  9. Jquery--仿制360右下角弹出窗口
  10. ES踩坑笔记
  11. 2018年12月8日广州.NET微软技术俱乐部活动总结
  12. python模块shutil
  13. activate-power-mode 插件 安装 设置 IDEA
  14. Effective Java 第三版——58. for-each循环优于传统for循环
  15. 常用Build-in Keywords
  16. sass问题
  17. php中一些常用的语句收集
  18. Java中的String和StringBuffer
  19. c#(winform)环境下使用动态链接库dll的详解
  20. 使用TimeSpan对象获取时间间隔

热门文章

  1. R shinydashboard——3.外观
  2. 爬虫动态渲染页面爬取之selenium驱动chrome浏览器的使用
  3. Django向数据库批量插入数据
  4. bwa比对软件的使用以及其结果文件(sam)格式说明
  5. 通用的js异步ajax文件上传函数
  6. [转] Java中对数据进行加密的几种方法
  7. Can references refer to invalid location in C++?
  8. keepalived 高可用lvs的dr模型(vip与dip不在同一网段)
  9. C语言编辑链接
  10. &#127942;【Alibaba中间件技术系列】「RocketMQ技术专题」Broker配置介绍及发送流程、异常(XX Busy)问题分析