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];
        }
    }
}
相关推荐
我要学编程(ಥ_ಥ)17 分钟前
一文详解“二叉树中的深搜“在算法中的应用
java·数据结构·算法·leetcode·深度优先
埃菲尔铁塔_CV算法19 分钟前
FTT变换Matlab代码解释及应用场景
算法
许野平1 小时前
Rust: enum 和 i32 的区别和互换
python·算法·rust·enum·i32
chenziang11 小时前
leetcode hot100 合并区间
算法
chenziang11 小时前
leetcode hot100 对称二叉树
算法·leetcode·职场和发展
szuzhan.gy2 小时前
DS查找—二叉树平衡因子
数据结构·c++·算法
一只码代码的章鱼2 小时前
排序算法 (插入,选择,冒泡,希尔,快速,归并,堆排序)
数据结构·算法·排序算法
青い月の魔女3 小时前
数据结构初阶---二叉树
c语言·数据结构·笔记·学习·算法
林的快手3 小时前
209.长度最小的子数组
java·数据结构·数据库·python·算法·leetcode
千天夜3 小时前
多源多点路径规划:基于启发式动态生成树算法的实现
算法·机器学习·动态规划