题目描述:

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

初始化 nums1 和 nums2 的元素数量分别为 m 和 n 。你可以假设 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 = [1], m = 1, nums2 = [], n = 0
输出:[1]
 

提示:

nums1.length == m + n
nums2.length == n
0 <= m, n <= 200
1 <= m + n <= 200
-109 <= nums1[i], nums2[i] <= 109

解题思路:

class Solution {
    public void merge(int[] nums1, int m, int[] nums2, int n) {
        int[] nums1copy=new int[m];
        //创建一个新的数组,并将nums1拷贝进其中,把nums1当成容器使用
        System.arraycopy(nums1,0,nums1copy,0,m);
        //三个指针变量
        int p1,p2,p;
        p=p1=p2=0;
        while(p1<m&&p2<n){
            //小的先进入数组num1中
            if(nums1copy[p1]<=nums2[p2]){
                nums1[p]=nums1copy[p1];
                p1++;
            }
            else{
                nums1[p]=nums2[p2];
                p2++;
            }
            p++;
        }
        //继续剩下部分的拷贝
        if(p1==m){
            for(int i=p2;i<n;i++){
                nums1[p]=nums2[i];
                p++;
            }
        }
        else{
            for(int i=p1;i<m;i++){
                nums1[p]=nums1copy[i];
                p++;
            }
        }
        
    }
}

 

posted on 2021-03-29 18:30  wxcongajiayou  阅读(51)  评论(0)    收藏  举报