入门客AI创业平台(我带你入门,你带我飞行)
博文笔记

两升序数组合并成一个升序数组

创建时间:2012-11-05 投稿人: 浏览次数:3360
package test;

import java.util.Arrays;

public class LArray {

	public static void main(String[] args){
		int[] a={2,6,7,8}; int[] b={4,6,66,77,88,99,444,666,777,999};
		int[] c = uninArray(a,b);
		System.out.println(Arrays.toString(c));
	}
	
	public  static int[] uninArray(int[] a,int[] b){
		int left=0,mid=0,third=0;
		int[] tmpArr=new int[a.length+b.length];
		while (left< a.length && mid< b.length) {

			// 从两个数组中取出最小的放入中间数组
			if (a[left] <= b[mid]) {
				tmpArr[third++] = a[left++];
			} else {
				tmpArr[third++] = b[mid++];
			}
		}
		// 剩余部分依次放入中间数组
		while (mid < b.length) {
			tmpArr[third++] = b[mid++];
		}
		while (left <a.length) {
			tmpArr[third++] = a[left++];
		}
		return tmpArr;
	}
}

声明:该文观点仅代表作者本人,入门客AI创业平台信息发布平台仅提供信息存储空间服务,如有疑问请联系rumenke@qq.com。
  • 上一篇:没有了
  • 下一篇:没有了
未上传头像