Leetcode-88 合并两个有序数组

使用内置排序函数,时间复杂度On^2

java 复制代码
class Solution {
    public void merge(int[] nums1, int m, int[] nums2, int n) {
        int j=0,i=m;
        while(j<n){
            nums1[i++]=nums2[j++];
        }
        Arrays.sort(nums1);
    }
}

新建一个临时数组用于放排序后的元素,再将临时数组赋值给nums1,此方法仅遍历一次两个数组,时间复杂度Om+n

java 复制代码
class Solution {
    public void merge(int[] nums1, int m, int[] nums2, int n) {
        int k=m+n;
        int[] temp=new int[k];
        for(int index=0,nums1Index=0,nums2Index=0;index<k;index++){
            if(nums1Index>=m){
                temp[index]=nums2[nums2Index++];
            }else if(nums2Index>=n){
                temp[index]=nums1[nums1Index++];
            }else if(nums1[nums1Index]<nums2[nums2Index]){
                temp[index]=nums1[nums1Index++];
            }else{
                temp[index]=nums2[nums2Index++];
            }
        }
        for(int i=0;i<k;i++){
            nums1[i]=temp[i];
        }
    }
}
相关推荐
noipp20 分钟前
推荐题目:洛谷 P10907 [蓝桥杯 2024 国 B] 蚂蚁开会
c语言·c++·算法·编程·洛谷
程序员二叉1 小时前
【JUC】ThreadLocal底层原理|内存泄漏|弱引用|跨线程传递方案
java·开发语言·面试·职场和发展·juc
程序员二叉1 小时前
【JUC】线程池全套深度详解|参数|流程|拒绝策略|调优|异常处理
java·开发语言·jvm·算法·面试·juc
青山木1 小时前
Hot 100 --- 轮转数组
java·数据结构·算法
徐小夕2 小时前
Loop Engineering 深度解析与实战指南(全网最全)
前端·算法·github
北域码匠3 小时前
SHA-1算法:安全哈希原理与应用解析
算法·c#·哈希算法
手写码匠4 小时前
手写 GraphRAG:从零实现图增强检索增强生成系统
人工智能·深度学习·算法·aigc
BomanGe14 小时前
NSK重载高刚性滚珠丝杠技术详解
经验分享·算法·规格说明书
Matrix_114 小时前
手机里的计算摄影:广角形变校正算法
人工智能·算法·智能手机·计算摄影
WBluuue4 小时前
数据结构与算法:有序表(二):跳表
数据结构·c++·算法·skiplist