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

合并两个有序的数组

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,
};

全部评论

相关推荐

04-10 11:56
如皋中学 Java
高斯林的信徒:双c9能简历挂的?
点赞 评论 收藏
分享
04-27 08:59
常州大学 Java
韵不凡:软件开发的工作需要博士吗?
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务