合并两个有序数组python

给定两个有序整数数组 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]

# -*- coding:utf-8 -*-
#@author:xinxinzhang 
'''
思路:主要通过形参改变实参
直接concat或者+只在函数内有效
'''

def merge(nums1, m, nums2, n):
    while m>0 and n>0:
        if nums1[m-1]>nums2[n-1]:#若nums1中最后一个元素大于nums2[]中最后一个元素
            nums1[m+n-1]=nums1[m-1]#则扩展后的列表最后一个元素是俩元素中最大的
            m-=1       #nums1中元素-1
        else:
            nums1[m+n-1]=nums2[n-1]
            n-=1
    if n>0:#若nums1完了,nums2还没完
        nums1[:n]=nums2[:n]#把剩下nums2加在最开始

if __name__=='__main__':
    nums1 = [0]#0的位置用来方nums2
    m = 0
    nums2 = [2, 5, 6]
    n = 3
    merge(nums1,m,nums2,n)
    print(nums1)

你可能感兴趣的:(python编程练习)