088 合并两个有序数组

题目

给定两个有序整数数组 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]

实现

  • 状态:通过
  • 59 / 59 个通过测试用例
  • 执行用时: 348 ms, 在所有 C# 提交中击败了 93.33% 的用户
  • 内存消耗: 29.2 MB, 在所有 C# 提交中击败了 6.43% 的用户
public class Solution
{
    public void Merge(int[] nums1, int m, int[] nums2, int n)
    {
        int j = 0;
        for (int i = 0; i < n; i++)
        {
            int num2 = nums2[i];
            while (num2 > nums1[j] && j < m)
            {
                j++;
            }
            int k = m;
            while (k > j)
            {
                nums1[k] = nums1[k - 1];
                k--;
            }
            m++;
            nums1[j] = num2;
        }
    }
}
浙ICP备19012682号