[88][简单][双指针] 合并两个有序数组
题目描述
输入:nums1 = [1,2,3,0,0,0], m = 3, nums2 = [2,5,6], n = 3
输出:[1,2,2,3,5,6]输入:nums1 = [1], m = 1, nums2 = [], n = 0
输出:[1]解题思路
最后更新于
输入:nums1 = [1,2,3,0,0,0], m = 3, nums2 = [2,5,6], n = 3
输出:[1,2,2,3,5,6]输入:nums1 = [1], m = 1, nums2 = [], n = 0
输出:[1]最后更新于
class Solution:
def merge(self, nums1: List[int], m: int, nums2: List[int], n: int) -> None:
"""
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:
n1, n2 = nums1[i], nums2[j]
if n1 >= n2:
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
return nums1