LeetCode 面试经典150题 88.合并两个有序数组

题目:

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

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

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

思路:从右向左比较,将大的放到末尾,定义三个指针分别表示m个元素的末尾、n个元素的末尾、合并后数组的末尾

代码

java 复制代码
class Solution {
    public void merge(int[] nums1, int m, int[] nums2, int n) {
        int p1 = m - 1, p2 = n - 1, p = m + n - 1;
        while(p2 >= 0) { // nums2 还有要合并的元素
            if (p1 >= 0 && nums1[p1] > nums2[p2]) { // 只有这一种情况将m的元素移动到右边
                nums1[p] = nums1[p1];
                p--;
                p1--;
            } else {
                nums1[p] = nums2[p2];
                p--;
                p2--;
            }
        }
    }
}

性能:时间复杂度O(m+n)

空间复杂度O(1)

相关推荐
熬了夜的程序员4 分钟前
【LeetCode】83. 删除排序链表中的重复元素
算法·leetcode·链表
Hilaku10 分钟前
技术、业务、管理:一个30岁前端的十字路口
前端·javascript·面试
胖咕噜的稞达鸭20 分钟前
AVL树手撕,超详细图文详解
c语言·开发语言·数据结构·c++·算法·visual studio
007php00736 分钟前
百度面试题解析:synchronized、volatile、JMM内存模型、JVM运行时区域及堆和方法区(三)
java·开发语言·jvm·缓存·面试·golang·php
YSRM40 分钟前
Leetcode+Java+图论II
java·leetcode·图论
熊猫钓鱼>_>43 分钟前
Rust语言特性深度解析:所有权、生命周期与模式匹配之我见
算法·rust·软件开发·函数·模式匹配·异步编程·质量工具
luckyPian1 小时前
前端+AI:HTML5语义标签(一)
前端·ai·面试·html·html5·ai编程
芒果量化1 小时前
Optuna - 自动调参利器&python实例
开发语言·python·算法·机器学习
麦麦大数据1 小时前
D025 摩托车推荐价格预测可视化系统|推荐算法|机器学习|预测算法|用户画像与数据分析
mysql·算法·机器学习·django·vue·推荐算法·价格预测
Baihai_IDP1 小时前
LLM 应用评估综合指南(多轮对话系统、RAG、AI Agent)
人工智能·面试·llm