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>());


    }
};
相关推荐
小月球~1 小时前
天梯赛 · 并查集
数据结构·算法
仍然.2 小时前
算法题目---模拟
java·javascript·算法
6Hzlia3 小时前
【Hot 100 刷题计划】 LeetCode 118. 杨辉三角 | C++ 动态规划题解
c++·leetcode·动态规划
潇冉沐晴4 小时前
DP——背包DP
算法·背包dp
GIOTTO情4 小时前
2026 世界互联网大会亚太峰会|AI 时代媒介投放的技术实战与算法优化
人工智能·算法
逆境不可逃4 小时前
LeetCode 热题 100 之 543. 二叉树的直径 102. 二叉树的层序遍历 108. 将有序数组转换为二叉搜索树 98. 验证二叉搜索树
算法·leetcode·职场和发展
计算机安禾4 小时前
【数据结构与算法】第19篇:树与二叉树的基础概念
c语言·开发语言·数据结构·c++·算法·visual studio code·visual studio
副露のmagic5 小时前
哈希章节 leetcode 思路&实现
算法·leetcode·哈希算法
副露のmagic5 小时前
字符串章节 leetcode 思路&实现
windows·python·leetcode
csuzhucong5 小时前
puzzle(1037)黑白、黑白棋局
算法