题解 | #合并两个有序的数组#

合并两个有序的数组

http://www.nowcoder.com/practice/89865d4375634fc484f3a24b7fe65665

双指针 ,分区

/**
 *
 * @param A int整型一维数组
 * @param B int整型一维数组
 * @return void
 */
function merge(A, m, B, n) {
  // write code here
  let pn = n - 1,
    pm = m - 1,
    pmn = m + n - 1;
  while (pmn >= 0) {
    if (pn < 0 || pm < 0) {
      if (pm < 0) {
        A[pmn] = B[pn];
        pn--;
      } else {
        A[pmn] =  A[pm];
        pm--;
      }
    } else {
      if (A[pm] > B[pn]) {
        A[pmn] = A[pm];
        pm--;
      } else {
        A[pmn] = B[pn];
        pn--;
      }
    }
    pmn--;
  }

  return A;
}
module.exports = {
  merge: merge,
};

全部评论

相关推荐

10-16 15:48
算法工程师
点赞 评论 收藏
分享
10-02 19:29
已编辑
浙江科技大学 运营
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务