【leetcode】88. 合并两个有序数组(图解)

目录

  • [1. 思路(图解)](#1. 思路(图解))
  • [2. 代码](#2. 代码)

题目链接:leetcode 88. 合并两个有序数组

题目描述:

1. 思路(图解)

复制代码
思路一:(不满足题目要求)
1. 创建一个大小为nums1和nums2长度之和的数组;
2. i1和i2作为两个数组下标;
3. nums[i1]与num2[i2]比较,向新数组依次存入较小的值,i1和i2谁小谁自增;
4. 将num1或nums2剩余的元素存入新数组。

思路二:
1. 从后往前遍历,i1和i2作为nums1和nums2数组最后一个有效值元素下标;
2. i1 >= 0 且 i2 >= 0作为循环条件;
3. 变量j作为下标指向nums1最后下标位置;
4. nums[i1]与nums[i2]比较,谁大就往nums[j]赋值,然后下标值自减;
5. 将剩余的元素放入nums1数组。


2. 代码

c 复制代码
void merge(int* nums1, int nums1Size, int m, int* nums2, int nums2Size, int n) {
    int i1 = m - 1;
    int i2 = n - 1;
    int j = nums1Size - 1;

    while (i1 >= 0 && i2 >= 0) {
        if (nums1[i1] > nums2[i2]) {
            nums1[j--] = nums1[i1--];
        }
        else {
            nums1[j--] = nums2[i2--];
        }
    }

    while (i2 >= 0) {
        nums1[j--] = nums2[i2--];
    }
}
相关推荐
cpp_25016 分钟前
P1873 [COCI 2011/2012 #5] EKO / 砍树
数据结构·c++·算法·题解·二分答案·洛谷·csp
啊哦呃咦唔鱼8 分钟前
leetcodehot100-347. 前 K 个高频元素
数据结构·算法·leetcode
玛丽莲茼蒿8 分钟前
Leetcode hot100 多数元素【简单】
算法·leetcode·职场和发展
AbandonForce9 分钟前
Map类:pair键值对|map的基本操作|operator[]
开发语言·c++·算法·leetcode
澈20711 分钟前
C++核心:封装与static静态成员实战指南
开发语言·c++·算法
田梓燊15 分钟前
力扣:146.LRU 缓存
算法·leetcode·缓存
_深海凉_22 分钟前
LeetCode热题100-杨辉三角
算法·leetcode·职场和发展
小O的算法实验室32 分钟前
2025年SEVC,面向进化计算的学习注入式优化,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
啊我不会诶41 分钟前
2024北京市赛补题
c++·算法
shehuiyuelaiyuehao42 分钟前
算法13,滑动窗口,水果成篮
算法·哈希算法·散列表