牛骨文教育服务平台(让学习变的简单)
博文笔记

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

创建时间:2014-06-11 投稿人: 浏览次数:5806

算法的基本步骤:

以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]);
		}
	}
}
以上仅供参考。

声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。