前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >合并排序数组

合并排序数组

作者头像
一份执着✘
发布2018-06-04 16:32:12
1.1K0
发布2018-06-04 16:32:12
举报
文章被收录于专栏:赵俊的Java专栏赵俊的Java专栏

题意

合并两个排序的整数数组A和B变成一个新的数组。

样例

给出A = [1,2,3,4],B = [2,4,5,6],返回 [1,2,2,3,4,4,5,6]

思路

创建一个新的数组,长度是 A 和 B 长度之合,再设三个指针,分别指向 A,B 和新数组的第一个元素,然后遍历两个数组,依次比较每一个元素,较小的数存入新数组中,并将较小值的指针与新数组的指针向后移动一位。最后当遍历完 A 或 B 以后,就将剩余数组的数据依次添加到新数组。

代码实现

class Solution {
    /**
     * @param A and B: sorted integer array A and B.
     * @return: A new sorted integer array
     */
    public int[] mergeSortedArray(int[] A, int[] B) {
        if (A == null || B == null) {
            return null;
        }
        
        int[] result = new int[A.length + B.length];
        
        int i = 0;
        int j = 0;
        int index = 0;
        
        while (i < A.length && j < B.length) {
            if (A[i] < B[j]){
                result[index++] = A[i++];
            } else {
                result[index++] = B[j++];
            }
        }
        
        while (i < A.length) {
            result[index++] = A[i++];
        }
        
        while (j < B.length) {
            result[index++] = B[j++];
        }
        
        return result;
    }
}

原题地址

LintCode:合并排序数组

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017-07-282,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题意
  • 样例
  • 思路
  • 代码实现
  • 原题地址
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档