【C语言】Leetcode 88.合并两个有序数组

简介: 【C语言】Leetcode 88.合并两个有序数组


一、代码实现

/**
 * 函数名称:merge
 * 
 * 功能描述:合并两个已排序的整数数组
 * 
 * 参数说明:
 *   nums1:第一个整数数组
 *   nums1Size:第一个数组的大小
 *   m:第一个数组中要合并的子数组的起始索引
 *   nums2:第二个整数数组
 *   nums2Size:第二个数组的大小
 *   n:第二个数组中要合并的子数组的起始索引
 */
 
void merge(int* nums1, int nums1Size, int m, int* nums2, int nums2Size, int n) 
{
    int end1 = m - 1;        // 定义第一个数组的结束索引
    int end2 = n - 1;        // 定义第二个数组的结束索引
    int end = m + n - 1;     // 定义合并后数组的结束索引
 
    while(end1 >= 0 && end2 >= 0) 
    {
        if(nums1[end1] > nums2[end2]) 
        { 
            // 如果第一个数组的当前元素大于第二个数组的当前元素
            nums1[end] = nums1[end1]; 
            // 将第一个数组的当前元素放到合并后数组的当前位置
            --end; 
            --end1; 
        }
        else
        {
            // 否则将第二个数组的当前元素放到合并后数组的当前位置
            nums1[end] = nums2[end2]; 
            --end2; 
            --end; 
        }
    }
 
    // 如果 end2 大于等于 0,说明 nums2 中还有剩余元素
    // 下面的循环用于将 nums2 中剩余的元素放到合并后数组的末尾
    while(end2 >= 0) 
    {
        nums1[end] = nums2[end2]; 
        --end; 
        --end2; 
    }
}

二、代码解释

  1. 首先,我们定义三个指针end1、end2和end,分别指向nums1、nums2和合并后数组的末尾。
  2. 使用while循环,当end1和end2均大于等于0时,比较nums1[end1]和nums2[end2]的大小,将较大的元素放入合并后数组的末尾,并依次向前移动指针end、end1或end2。
  3. 如果end2仍大于等于0,说明nums2中还有剩余元素未合并,继续将剩余元素放入合并后数组的末尾。
  4. 循环结束后,合并后的数组即存储在nums1中,且按非递减顺序排列

要注意的地方是在转移的最后剩余的是nums1还是nums2,因为是往nums1中添加,所以是nums1时不会产生影响。当剩余的是nums2时,由于添加的时候是按大的往进添加,而且nums1和nums2都是有序数组,所以剩余的nums2一定也是小于nums1的,按逻辑继续添加就可以正常实现。

以上是对合并两个有序数组的解题思路和代码解析。

目录
相关文章
|
3月前
leetCode(删除有序数组中的重复项)
如何在不使用额外空间的情况下,通过双指针法原地删除有序数组中的重复项。
38 2
|
5月前
|
存储 Java API
LeetCode------合并两个有序数组(4)【数组】
这篇文章介绍了LeetCode上的"合并两个有序数组"问题,并提供了三种解法:第一种是使用Java的Arrays.sort()方法直接对合并后的数组进行排序;第二种是使用辅助数组和双指针技术进行合并;第三种则是从后向前的双指针方法,避免了使用额外的辅助数组。
LeetCode------合并两个有序数组(4)【数组】
|
3月前
|
程序员 C语言
【C语言】LeetCode(力扣)上经典题目
【C语言】LeetCode(力扣)上经典题目
|
3月前
【LeetCode 48】108.将有序数组转换为二叉搜索树
【LeetCode 48】108.将有序数组转换为二叉搜索树
45 0
|
5月前
|
算法
LeetCode第26题删除有序数组中的重复项
这篇文章介绍了LeetCode第26题"删除有序数组中的重复项"的解题方法,通过使用双指针技巧,高效地去除数组中的相邻重复元素。
LeetCode第26题删除有序数组中的重复项
|
5月前
|
算法
LeetCode第80题删除有序数组中的重复项 II
文章介绍了LeetCode第80题"删除有序数组中的重复项 II"的解法,利用双指针技术在O(1)空间复杂度内原地删除重复元素,并总结了双指针技术在处理有序数组问题中的应用。
LeetCode第80题删除有序数组中的重复项 II
|
5月前
|
算法
LeetCode第88题合并两个有序数组
文章分享了LeetCode第88题"合并两个有序数组"的解法,通过从后向前的合并策略避免了数组元素的前移,使用三个指针高效地完成了合并过程。
|
5月前
|
Python
【Leetcode刷题Python】108. 将有序数组转换为二叉搜索树
LeetCode上108号问题"将有序数组转换为二叉搜索树"的Python实现,通过递归选取数组中间值作为根节点,构建高度平衡的二叉搜索树。
32 2
|
5月前
|
算法 Java
LeetCode初级算法题:环形链表+排列硬币+合并两个有序数组java解法
LeetCode初级算法题:环形链表+排列硬币+合并两个有序数组java解法
59 0
|
5月前
|
Python
【Leetcode刷题Python】26. 删除有序数组中的重复项
本文提供了一种使用快慢指针法在原地删除升序数组中重复元素的Python实现,返回删除后数组的新长度,同时保持元素的相对顺序。
51 0