【CT】LeetCode手撕—88. 合并两个有序数组

目录

  • 题目
  • [1- 思路](#1- 思路)
  • [2- 实现](#2- 实现)
    • [⭐88. 合并两个有序数组------题解思路](#⭐88. 合并两个有序数组——题解思路)
  • [2- ACM实现](#2- ACM实现)

题目


1- 思路

模式识别

  • 模式1:两个有序数组合并 ------> 双指针
  • 模式2:返回结果填充到 nums1[m+n] ------> 需要开辟新的数组空间 sorted[m+n] 最后结果赋值给 nums1

思路

  • 1.定义双指针 :分别指向 nums1nums2
  • 2.开辟新的数组空间sorted[m+n] ,在合并完之后赋值

2- 实现

⭐88. 合并两个有序数组------题解思路

java 复制代码
class Solution {
    public void merge(int[] nums1, int m, int[] nums2, int n) {
        int[] sorted = new int[m+n];
        int si = 0;
        int index1=0,index2=0;
        while(index1<m && index2<n){
            if(nums1[index1]<=nums2[index2]){
                sorted[si++] = nums1[index1++];
            }else{
                sorted[si++] = nums2[index2++];
            }
        }

        while(index1<m){
            sorted[si++] = nums1[index1++];
        }
        while(index2<n){
            sorted[si++] = nums2[index2++];
        }
        // 赋值给 nums1
        for(int i = 0 ; i < m+n;i++){
            nums1[i] = sorted[i];
        }
    }
}

2- ACM实现

java 复制代码
public class mergeTwoArrays {

    public static int[] mergeTwoArrays(int[] nums1,int m, int[] nums2,int n){
        int index1 = 0,index2 = 0;
        int si = 0;
        int[] sorted = new int[m+n];
        while(index1<m && index2<n){
            if(nums1[index1]<=nums2[index2]){
                sorted[si++] = nums1[index1++];
            }else{
                sorted[si++] = nums2[index2++];
            }
        }
        while(index1<m){
            sorted[si++] = nums1[index1++];
        }
        while(index2<n){
            sorted[si++] = nums2[index2++];
        }
        for(int i = 0 ; i < m+n;i++){
            nums1[i] = sorted[i];
        }
        return nums1;
    }

    public static void main(String[] args) {
        System.out.println("输入数组1和数组2长度 m 和 n");
        Scanner sc = new Scanner(System.in);
        int m = sc.nextInt();
        int n = sc.nextInt();

        int[] nums1 = new int[m+n];

        int[] nums2 = new int[n];

        System.out.println("输入数组1");
        for(int i = 0 ; i <m;i++){
            nums1[i] = sc.nextInt();
        }
        System.out.println("输入数组2");
        for(int j = 0 ; j < n;j++){
            nums2[j] = sc.nextInt();
        }
        int[] res = mergeTwoArrays(nums1,m,nums2,n);
        for(int r:res){
            System.out.print(r+" ");
        }
    }
}
相关推荐
点云SLAM2 小时前
二叉树算法详解和C++代码示例
数据结构·c++·算法·红黑树·二叉树算法
今天背单词了吗9809 小时前
算法学习笔记:19.牛顿迭代法——从原理到实战,涵盖 LeetCode 与考研 408 例题
笔记·学习·算法·牛顿迭代法
jdlxx_dongfangxing10 小时前
进制转换算法详解及应用
算法
why技术11 小时前
也是出息了,业务代码里面也用上算法了。
java·后端·算法
2501_9228955811 小时前
字符函数和字符串函数(下)- 暴力匹配算法
算法
IT信息技术学习圈12 小时前
算法核心知识复习:排序算法对比 + 递归与递推深度解析(根据GESP四级题目总结)
算法·排序算法
愚润求学12 小时前
【动态规划】01背包问题
c++·算法·leetcode·动态规划
会唱歌的小黄李12 小时前
【算法】贪心算法入门
算法·贪心算法
轻语呢喃13 小时前
每日LeetCode : 两数相加--链表操作与进位的经典处理
javascript·算法
钢铁男儿13 小时前
C# 接口(接口可以继承接口)
java·算法·c#