首页 > 其他分享 >88. 合并两个有序数组

88. 合并两个有序数组

时间:2023-08-13 22:01:35浏览次数:39  
标签:数组 int 合并 -- 88 有序 nums1 nums2

88. 合并两个有序数组

2023年8月13日17:05:45

88. 合并两个有序数组

简单

给你两个按 非递减顺序 排列的整数数组 nums1nums2,另有两个整数 mn ,分别表示 nums1nums2 中的元素数目。

请你 合并 nums2nums1 中,使合并后的数组同样按 非递减顺序 排列。

注意:最终,合并后数组不应由函数返回,而是存储在数组 nums1 中。为了应对这种情况,nums1 的初始长度为 m + n,其中前 m 个元素表示应合并的元素,后 n 个元素为 0 ,应忽略。nums2 的长度为 n

示例 1:

输入:nums1 = [1,2,3,0,0,0], m = 3, nums2 = [2,5,6], n = 3
输出:[1,2,2,3,5,6]
解释:需要合并 [1,2,3] 和 [2,5,6] 。
合并结果是 [1,2,2,3,5,6] ,其中斜体加粗标注的为 nums1 中的元素。

示例 2:

输入:nums1 = [1], m = 1, nums2 = [], n = 0
输出:[1]
解释:需要合并 [1] 和 [] 。
合并结果是 [1] 。

示例 3:

输入:nums1 = [0], m = 0, nums2 = [1], n = 1
输出:[1]
解释:需要合并的数组是 [] 和 [1] 。
合并结果是 [1] 。
注意,因为 m = 0 ,所以 nums1 中没有元素。nums1 中仅存的 0 仅仅是为了确保合并结果可以顺利存放到 nums1 中。

提示:

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

进阶:你可以设计实现一个时间复杂度为 O(m + n) 的算法解决此问题吗?

通过次数

960.2K

提交次数

1.8M

通过率

52.7%

答案

class Solution {
    public void merge(int[] nums1, int m, int[] nums2, int n) {
        if(n == 0 )
            return ;

        if(m==0&& n!=0){
            for(int i = 0;i<n;i++){
                nums1[i] = nums2[i];
            }
            return ;
        }
        int i = m-1;
        int j = n-1;
        int k = m+n-1;
        for(;i>=0&&j>=0;k--){
                if(nums1[i]<nums2[j]){
                    nums1[k] = nums2[j];
                    j--;
                }
                else{
                    nums1[k] = nums1[i];
                    i--; 
                }  
        }
            for(;i>=0;i--,k--)
                nums1[k] = nums1[i];
        
            for(;j>=0;j--,k--)
                nums1[k] = nums2[j];
        
    }
}

标签:数组,int,合并,--,88,有序,nums1,nums2
From: https://www.cnblogs.com/lmq886/p/17627363.html

相关文章

  • M2版Mac mini被京东杀到史低2888元!比苹果官网低1600
    苹果跳水王M2版Macmini又降价了。根据京东官方百亿补贴频道显示,Macmini8+256GB入门版只要2888元了,比前不久的拼多多2959还低,刷新了这款电脑的史上最低价。对比官网原价的4499元,直接跌掉超过1600元,已经非常值得入手。尤其是Macmini对比同价位的Windows迷你机,不论是性能还是......
  • 3 字符串向量数组
    当把string对象和子符字面值混在一条语句中使用时,必须确保每个+运算符的两侧的运算对象至少有一个是string用花括号对vector做初始化,不能用下标形式添加元素迭代器,iterator const_iterator两种迭代器类型,如果vector或string对象是常量,只能使用const_iterator。对vect......
  • 数组的运用
    数组的使用For-Each循环数组作方法入参数组作返回值packagearray;​publicclassArrayDemo04{  publicstaticvoidmain(String[]args){    int[]arrays={1,2,3,4,5};    //打印全部数组元素    for(inti=0;i<arrays.leng......
  • #yyds干货盘点# LeetCode程序员面试金典:数组中的第K个最大元素
    题目:给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。你必须设计并实现时间复杂度为 O(n) 的算法解决此问题。 示例1:[3,2,1,5,6,4],示例 2:[3,2,3,1,2,4,5,5,6],代码实现:class......
  • 算法刷题:数组题(持续更)
    算法刷题系列:算法刷题:链表题(持续更)力扣链接:删除有序数组中的重复项删除排序链表中的重复元素移除元素移除链表元素两数之和反转字符串反转链表验证回文串验证回文串II目录快速排序原理代码实现快慢指针注意事项异步移动删除有序数组的重复项代码实现对比链表的删......
  • 数组
    数组是存放在连续内存空间上的相同类型数据的集合。数组可以方便地通过下标索引的方式获取到下标下对应的数据。因为数组的内存空间地址是连续的,所以在删除和添加元素的时候,就要移动其他元素的地址。数组的元素是不能删除的,只能覆盖。二维数组的存储如下: ......
  • 数组及元组
    第3章数组及元组3.1定长数组定义长度不变的数组可以使用ArrayScala数组的底层实际上是Java数组。例如字符串数组在底层就是Java的String[],整数数组在底层就是Java的Int[]valnums=newArray[Int](10)//生成10个整数的数组,所有元素初始化为0valnums=newArray[String](......
  • 树状数组
    前置知识:lowbit运算\(lowbit(x)\)表示正整数\(x\)在二进制表示下最低位的\(1\)跟后面的\(0\)构成的数值,有\(lowbit(x)=x\)&$($~\(~x+1)\),即\(lowbit(x)=x\)&\(-x\),理由如下:\(lowbit(x)\)是最后一位\(1\)所以跟前面的位没啥关系,祂在二进制表示下肯定就是\(......
  • 链表和数组的区别
    链表和数组的区别链表逻辑上相邻的元素在物理位置上不一定相邻。优点:插入、删除效率高,不需要一个连续的很大的内存缺点:查找某一个位置的元素效率低。数组优点:存取速度快缺点:1.整块连续空间,占很大内存。2.插入或删除数据效率低、不方便链表数组逻辑上相......
  • 随笔-C-指针数组使用简记
    typedefstructmem_list*cns_detail_encode_result[encode_type_max];(gdb)p&((structmem_list**)0x7fffb4557950)[0]#&取对应点的位置$29=(structmem_list**)0x7fffb4557950(gdb)p((structmem_list**)0x7fffb4557950)+0$30=(structmem_list**)......