关于算法:修订版Leetcode-88-合并两个有序数组

3次阅读

共计 783 个字符,预计需要花费 2 分钟才能阅读完成。

给你两个有序整数数组 nums1nums2,请你将 nums2 合并到 nums1 中,使 nums1 成为一个有序数组。

初始化 nums1nums2 的元素数量别离为 mn。你能够假如 nums1 的空间大小等于 m + n,这样它就有足够的空间保留来自 nums2 的元素。

示例 1:

输出:nums1 = [1,2,3,0,0,0], m = 3, nums2 = [2,5,6], n = 3
输入:[1,2,2,3,5,6]

示例 2:

输出:nums1 = [0], m = 0, nums2 = [1], n = 1
输入:[1]

示例 3:

输出:nums1 = [5, 6, 7, 8, 0, 0, 0], m = 4, nums2 = [2, 3, 3], n = 3
输入:[2, 3, 3, 5, 6, 7, 8]

解题思路

这道题显著是从 nums1 数组最初,依照倒序的形式进行合并。应用双指针法合并两个有序数组,比拟两个元素大小,将较大的元素从前面合入。当其中一个数组全副合并之后,只需把另一个数组残余元素合并过去即可。

class Solution {public void merge(int[] nums1, int m, int[] nums2, int n) {
        // 应用双指针法合并两个有序数组
        // i => nums1 数组起始下标
        // j => nums2 数组起始下标
        int i = m - 1, j = n - 1;
        for (int p = nums1.length - 1; p >= 0; p--) {if (i == -1) {
                // nums1 已全副被合并,只需把 nums2 合并过去即可
                nums1[p] = nums2[j--];
            } else if (j == -1) {
                // nums2 已全副被合并,只需把 nums1 合并过去即可
                nums1[p] = nums1[i--];
            } else if (nums1[i] > nums2[j]) {
                // 将较大的元素合入,同时下标后退一位
                nums1[p] = nums1[i--];
            } else {nums1[p] = nums2[j--];
            }
        }
    }
}
正文完
 0