LeetCode热题100-88. 合并两个有序数组

这个题不在hot-100

给你两个按 非递减顺序 排列的整数数组 nums1nums2,另有两个整数 mn ,分别表示 nums1nums2 中的元素数目。

请你 合并 nums2nums1 中,使合并后的数组同样按 非递减顺序 排列。

注意: 最终,合并后数组不应由函数返回,而是存储在数组 nums1 中。为了应对这种情况,nums1 的初始长度为 m + n,其中前 m 个元素表示应合并的元素,后 n 个元素为 0 ,应忽略。nums2 的长度为 n

首先想到的就是合并后排序就OK,时间复杂度为O(m+n)log(m+n).

python 复制代码
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.
        """
        l = m
        for i in range(len(nums2)):
            nums1[l] = nums2[i]
            l += 1
        nums1.sort()
        

第二种依赖数组有序,可以使用三针指的方法。时间复杂度O(m + n)

python 复制代码
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 = m - 1
        j = 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
相关推荐
東隅已逝,桑榆非晚1 分钟前
深⼊理解指针(5)
c语言·笔记·算法
lwf0061645 分钟前
顺序模型学习日记
算法
_日拱一卒9 分钟前
LeetCode:199二叉树的右视图
算法·leetcode·职场和发展
The Chosen One98516 分钟前
分享对dp题目的理解-不断更新ing
笔记·算法·深度优先·动态规划·dp
有时间要学习20 分钟前
【无标题】
算法
re林檎21 分钟前
算法札记——5.15
算法
鱼子星_26 分钟前
【数据结构与算法】OJ题目详解(一)-单链表:从易到难的面试OJ题目
c语言·数据结构·算法·链表·面试·职场和发展
人道领域26 分钟前
【LeetCode刷题日记】递归与回溯实战 257.二叉树的所有路径——一篇文章彻底搞懂回溯
开发语言·python·算法·leetcode
ulias21228 分钟前
leetcode热题 - 7
数据结构·算法·leetcode
吃好睡好便好30 分钟前
在Matlab中用sphere( )函数绘制球面图
开发语言·前端·javascript·学习·算法·matlab·信息可视化