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

合并两个有序的数组

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

全部评论

相关推荐

不愿透露姓名的神秘牛友
昨天 11:35
程序员小白条:话太多,没实力和学历,差不多回答回答就行了,身份地位不一样
点赞 评论 收藏
分享
_mos_:我以为手抄报简历就已经很顶了,没想到还有表格简历
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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