首页 > 编程语言 > 详细

88. 合并两个有序数组

时间:2021-03-29 20:44:16      阅读:30      评论:0      收藏:0      [点我收藏+]

题目描述:

给你两个有序整数数组 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++;
            }
        }
        
    }
}

 

88. 合并两个有序数组

原文:https://www.cnblogs.com/congajiayou/p/14593694.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!