leetcode88--合并两个有序数组

1. 题意

将两个非逆序合并到其中一个中来。

合并两个有序数组

2. 题解

2.1 合并排序

先将另个数组的值放在前面数组的末尾,再对数组进行排序。

cpp 复制代码
class Solution {
public:
    void merge(vector<int>& nums1, int m, vector<int>& nums2, int n) {


        copy(nums2.begin(), nums2.end(), nums1.begin() + m);
        sort(nums1.begin(), nums1.end(), less<int>());


    }
};
// Time: O(ologn) Space: O(m+n)
2.2 双指针加辅助数组
cpp 复制代码
class Solution {
public:
    void merge(vector<int>& nums1, int m, vector<int>& nums2, int n) {
        vector<int> aux(m + n, 0);

        int p  = 0;
        int p1 = 0;
        int p2 = 0;


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

        copy(aux.begin(), aux.end(), nums1.begin());
        for(auto c:aux)
            std::cout << c << " ";

    }
};
2.3 双指针加逆序优化空间
cpp 复制代码
class Solution {
public:
    void merge(vector<int>& nums1, int m, vector<int>& nums2, int n) {


        copy(nums2.begin(), nums2.end(), nums1.begin() + m);
        sort(nums1.begin(), nums1.end(), less<int>());


    }
};
相关推荐
NAGNIP16 分钟前
Transformer注意力机制——MHA&MQA&GQA
人工智能·算法
NAGNIP21 分钟前
一文搞懂KV-Cache
人工智能·算法
CoovallyAIHub27 分钟前
RTMPose:重新定义多人姿态估计的“实时”标准!
深度学习·算法·计算机视觉
爱喝茶的小茶41 分钟前
周赛98补题
开发语言·c++·算法
小庞在加油2 小时前
《dlib库中的聚类》算法详解:从原理到实践
c++·算法·机器学习·数据挖掘·聚类
ComputerInBook2 小时前
C++ 标准模板库算法之 transform 用法
开发语言·c++·算法·transform算法
hn小菜鸡8 小时前
LeetCode 377.组合总和IV
数据结构·算法·leetcode
Deepoch8 小时前
Deepoc 大模型:无人机行业的智能变革引擎
人工智能·科技·算法·ai·动态规划·无人机
heimeiyingwang9 天前
【深度学习加速探秘】Winograd 卷积算法:让计算效率 “飞” 起来
人工智能·深度学习·算法
时空自由民.9 天前
C++ 不同线程之间传值
开发语言·c++·算法