leetcode 88. 合并两个有序数组

90 阅读1分钟

88. 合并两个有序数组 - 力扣(LeetCode)

image.png

image.png

image.png

方法2 辅助空间

开辟一个vector<int> result

给result开nums1一样大的空间 (m+n)。

然后用双指针分别指向nums1,nums2开头,比较大小,谁小就往result里面放。

排完之后result就是有序的数组。

最后nums1result里面的值全部添加进来。

code

注意事项

请拿图(3-0)自行演草

class Solution {
public:
    void merge(vector<int>& nums1, int m, vector<int>& nums2, int n) {
        vector<int> res(m + n); // 创建新数组存储合并后的结果
        int i = 0, j = 0, k = 0;
        // 比较两个数组的元素,将较小的元素放入新数组中
        while (i < m && j < n) {
            if (nums1[i] <= nums2[j]) {
                res[k++] = nums1[i++];
            }
            else {
                res[k++] = nums2[j++];
            }
        }
        // 将剩余的元素依次放入新数组中
        while (i < m) {
            res[k++] = nums1[i++];
        }
        while (j < n) {
            res[k++] = nums2[j++];
        }
        // 将新数组的内容复制回原数组
        for (int i = 0; i < m + n; i++) {
            nums1[i] = res[i];
        }
    }
};




不开辅助空间


```cpp
class Solution {
public:
    void merge(vector<int>& nums1, int m, vector<int>& nums2, int n) {
        int i = m - 1;
        int j = n - 1;
        int k = m + n - 1;

        while (i >= 0 && j >= 0) {
            if (nums1[i] > nums2[j]) {
                nums1[k--] = nums1[i--];
            } else {
                nums1[k--] = nums2[j--];
            }
        }

        while (j >= 0) {
            nums1[k--] = nums2[j--];
        }
    }
};