算法题 — 合并两个有序数组

合并两个有序数组

两个有数整数数组 nums1 和 nums2,将 nums2 合并到 nums1 中,使 nums1 成为一个有序数组。

初始化 nums1 和 nums2 的元素数量分别为 m 和 n。假设 nums1 的空间大小等于 m + n,这样它就能有足够的空间保存来自 nums2 的元素。

java 复制代码
public static int[] merge(int[] nums1, int m, int[] nums2, int n) {
    // num2: 要复制的源数组; 0: 源数组要复制的起始位置(从0开始);
    // nums1: 要复制的目标数组 m: 目标数组的起始位置 n: 要复制的长度;
    System.arraycopy(nums2, 0, nums1, m, n);
    Arrays.sort(nums1);
    return nums1;
}

public static int[] merge1(int[] nums1, int m, int[] nums2, int n) {
    int[] nums1_copy = new int[m];
    System.arraycopy(nums1, 0, nums1_copy, 0, m);

    int p1 = 0; // 指向 nums1_copy
    int p2 = 0; // 指向 nums2
    int p = 0; // 指向 nums1

    while (p1 < m && p2 < n) {
        nums1[p++] = nums1_copy[p1] < nums2[p2] ? nums1_copy[p1++] : nums2[p2++];
    }

    if (p1 < m) {
        System.arraycopy(nums1_copy, p1, nums1, p1 + p2, m + n - p1 - p2);
    }
    if (p2 < n) {
        System.arraycopy(nums2, p2, nums1, p1 + p2, m + n - p1 - p2);
    }

    return nums1;
}

public static int[] merge3(int[] nums1, int m, int[] nums2, int n) {
    int p1 = m - 1;
    int p2 = n - 1;
    int p = m + n - 1;

    while (p1 >= 0 && p2 >= 0) {
        nums1[p--] = nums1[p1] < nums2[p2] ? nums2[p2--] : nums1[p1--];
    }
    System.out.println(Arrays.toString(nums1));
    System.out.println(Arrays.toString(nums2));

    System.arraycopy(nums2, 0, nums1, 0, p2 + 1);
    return nums1;
}

int[] nums1 = new int[]{1, 3, 5, 7, 9, 0, 0, 0, 0};
int[] nums2 = new int[]{2, 4, 6, 8};
System.out.println(Arrays.toString(merge3(nums1, 5, nums2, 4)));
相关推荐
RainbowSea3 分钟前
跨域问题(Allow CORS)解决(3 种方法)
java·spring boot·后端
掘金-我是哪吒4 分钟前
分布式微服务系统架构第155集:JavaPlus技术文档平台日更-Java线程池实现原理
java·分布式·微服务·云原生·架构
RainbowSea7 分钟前
问题 1:MyBatis-plus-3.5.9 的分页功能修复
java·spring boot·mybatis
前端 贾公子11 分钟前
monorepo + Turborepo --- 开发应用程序
java·前端·javascript
三维重建-光栅投影22 分钟前
VS中将cuda项目编译为DLL并调用
算法
不学会Ⅳ1 小时前
Mac M芯片搭建jdk源码环境(jdk24)
java·开发语言·macos
虫小宝1 小时前
高佣金返利平台监控体系建设:APM、链路追踪与佣金异常预警系统技术实现
java
sniper_fandc2 小时前
SpringBoot系列—入门
java·spring boot·后端
课堂剪切板3 小时前
ch03 部分题目思路
算法
代码的余温3 小时前
Maven引入第三方JAR包实战指南
java·maven·jar