zoukankan      html  css  js  c++  java
  • leetcode- 88. 合并两个有序数组

    题目

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

    说明:

    初始化 nums1 和 nums2 的元素数量分别为 m 和 n。
    你可以假设 nums1 有足够的空间(空间大小大于或等于 m + n)来保存 nums2 中的元素。
    示例:

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

    输出: [1,2,2,3,5,6]

    思路

    1.倒车入库

    2.注意i++和++i的区别

    混合插入有序数组,由于两个数组都是有序的,所以只要按顺序比较大小即可。题目中说了nums1数组有足够大的空间,说明我们不用resize数组,又给了我们m和n,那就知道了混合之后的数组大小,这样我们就从nums1和nums2数组的末尾开始一个一个比较,把较大的数,按顺序从后往前加入混合之后的数组末尾。需要三个变量i,j,k,分别指向nums1,nums2,和混合数组的末尾。进行while循环,如果i和j都大于0,再看如果nums1[i] > nums2[j],说明要把nums1[i]先加入混合数组的末尾,加入后k和i都要自减1;else,就把nums2[j]加入混合数组的末尾,之后j和k也要自减1。循环结束后,有可能i和j还大于等于0,若j大于等于0,那么需要继续循环,将nums2中的数字继续拷入nums1。若是i大于等于0,那么就不用管,因为混合数组本身就房子nums1中。

    代码

    void merge(int* nums1, int nums1Size, int m, int* nums2, int nums2Size, int n){
        //倒车入库
        int i=m-1;
        int j=n-1;
        int cur=m+n-1;
    
    
        //从后向前遍历数组,将较大的数从数组nums1后面开始放置
        while(i>=0&&j>=0)
        {
            nums1[cur--]=nums1[i]>nums2[j]?nums1[i--]:nums2[j--];
        }
    
        // 将数组nums2中剩余的元素按顺序放入数组nums1中
        while(j >= 0)
            nums1[cur--] = nums2[j--];
    
    }
  • 相关阅读:
    SpringBoot+SpringCloud+vue+Element开发项目——集成Druid数据源
    SpringBoot+SpringCloud+vue+Element开发项目——集成MyBatis框架
    c语言double类型数据四舍五入
    陀螺仪、加速计、磁力计等传感器汇总 (转)
    sudo和man的tab自动补全
    linux系统资源网站
    gstreamer
    version `GLIBC_2.14' not found 解决方法.
    项目框架设计模式(转)
    Linux音频编程指南(转)
  • 原文地址:https://www.cnblogs.com/mhq-martin/p/12024979.html
Copyright © 2011-2022 走看看