• [LeetCode] Merge Sorted Array


    Given two sorted integer arrays A and B, merge B into A as one sorted array.

    Note:
    You may assume that A has enough space (size that is greater or equal to m + n) to hold additional elements from B. The number of elements initialized in A and B are m andn respectively.

    思路:从后往前复制,注意两个数组都为空或者其中一个数组为空的情况。

       时间复杂度O(n),空间复杂度O(1)

     1 class Solution {
     2 public:
     3     void merge(int A[], int m, int B[], int n) {
     4         if (n == 0)
     5             return;
     6         int index = m + n - 1;
     7         int ia = m - 1;
     8         int ib = n - 1;
     9         while (ia >=0 && ib >= 0) {
    10             A[index--] = A[ia] >= B[ib] ? A[ia--] : B[ib--];
    11         }
    12         while (ib >= 0) {
    13             A[index--] = B[ib--];
    14         }
    15     }
    16 };
  • 相关阅读:
    分红
    MyCat学习笔记
    vue 事例
    linux 端口
    vue安装
    react入门一(转)
    javascript 中各种继承方式的优缺点 (转)
    vue路由复习(转载)
    ES6新特性
    js面试中长见的算法题(转载)
  • 原文地址:https://www.cnblogs.com/vincently/p/4121008.html
Copyright © 2020-2023  润新知