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];
        }
    }
}
相关推荐
测试者家园6 分钟前
测试用例智能生成:是效率革命,还是“垃圾进,垃圾出”的新挑战?
人工智能·职场和发展·测试用例·测试策略·质量效能·智能化测试·用例设计
GIS瞧葩菜7 分钟前
Cesium 轴拖拽 + 旋转圈拖拽 核心数学知识
人工智能·算法·机器学习
m0_6860416113 分钟前
C++中的适配器模式变体
开发语言·c++·算法
txzrxz14 分钟前
结构体排序,双指针,单调栈
数据结构·算法·双指针算法·单调栈·结构体排序
AndrewHZ18 分钟前
【AI黑话日日新】什么是AI智能体?
人工智能·算法·语言模型·大模型·llm·ai智能体
wWYy.19 分钟前
算法:二叉树最大路径和
数据结构·算法
葱明撅腚20 分钟前
利用Python挖掘城市数据
python·算法·gis·聚类
We་ct23 分钟前
LeetCode 36. 有效的数独:Set实现哈希表最优解
前端·算法·leetcode·typescript·散列表
weixin_3954489134 分钟前
main.c_cursor_0129
前端·网络·算法
CS创新实验室1 小时前
《计算机网络》深入学:路由算法与路径选择
网络·计算机网络·算法