将两个有序数组归并为一个升序数组-Java实现

算法的基本步骤:

以2个排序好的数组M和数组N为例,i=0和j=0分别为M和N的起始下标。

1.M第一个元素与N第一个元素比较,如果M的第一个元素小于N的第一个元素值,此时新数组MN的第一个元素的值为M[i],下标为[i+j]

2.此时M的下标i+1,与N的第一个元素继续比较,如果M的第二元素大于N的第一元素值,此时新数组MN的第二个元素的值为N[j],下标为[i+j](实际上是i=1,j=0)

3.此时N的下标j+1,重复比较的过程,代码示例如下:

package com.sun.www.sort;
/**
 * 将两个有序数组归并为一个升序数组
 * */

public class OrderedArraySort {
	public int[] getArraySort(int[] m,int[] n){
		int im = 0;  //数组m的起始位置,用于数组m下标计数
		int jn = 0;
		int[] mn = new int[m.length + n.length];   //排序后新数组大小
		
		while(im < m.length && jn <n.length){
			if(m[im]<=n[jn]){
				mn[im + jn] = m[im];
				im++;
			}else{
				mn[im + jn] = n[jn];
				jn++;
			}
		}
		//其中一个数组最后的元素值小于第二个数组的某个元素值,遍历第二个数组剩余元素值加入新数组
		while(im < m.length){
			mn[im + jn] = m[im];
			im++;
		}
		while(jn < n.length){
			mn[im + jn] = n[jn];
			jn++;
		}
		return mn;
	}
	public static void main(String[] args) {
		int[] m = {1,3,5,7,9,11,12,13};
		int[] n = {2,3,6,8,10};
		OrderedArraySort oas = new OrderedArraySort();
		int[] mn = oas.getArraySort(m, n);
		for(int i=0;i<mn.length;i++){
			System.out.println(mn[i]);
		}
	}
}
以上仅供参考。

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值