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)

相关推荐
聪明的笨猪猪11 分钟前
Java Redis “核心基础”面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试
Miraitowa_cheems13 分钟前
LeetCode算法日记 - Day 68: 猜数字大小II、矩阵中的最长递增路径
数据结构·算法·leetcode·职场和发展·贪心算法·矩阵·深度优先
DIY全栈开发2 小时前
《MCU职位》面试问题
单片机·嵌入式硬件·面试
灵感__idea2 小时前
Hello 算法:让前端人真正理解算法
前端·javascript·算法
学习2年半3 小时前
小米笔试题:一元一次方程求解
算法
MATLAB代码顾问3 小时前
MATLAB绘制多种混沌系统
人工智能·算法·matlab
大前端helloworld3 小时前
前端梳理体系从常问问题去完善-网络篇
前端·面试
极客BIM工作室3 小时前
演化搜索与群集智能:五种经典算法探秘
人工智能·算法·机器学习
qq_574656253 小时前
java-代码随想录第66天|Floyd 算法、A * 算法精讲 (A star算法)
java·算法·leetcode·图论
金融街小单纯4 小时前
从蓝军建设中学习颠覆性质疑思维
人工智能·算法·机器学习