leetcod(004) - 合并两个有序数组

2019/03/04

合并两个有序数组

一、题目描述

1、English版本

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]

2、 中文版

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

说明:

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

示例:

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

输出: [1,2,2,3,5,6]

二、ruby方案

# 程序是好的,但是leetcode出了莫名其妙的问题,irb测试同一测试用例通过;
# 而且ruby不用考虑m/n越界
# @param {Integer[]} nums1
# @param {Integer} m
# @param {Integer[]} nums2
# @param {Integer} n
# @return {Void} Do not return anything, modify nums1 in-place instead.
def merge(nums1, m, nums2, n)
  array1 = nums1[0...m]
  array2 = nums2[0...n]
  (array1 + array2).sort!
end

三、python方案

同上

四、java方案

null

五、经典解法,算法思想


Show Disqus Comments

Post Directory