您的位置:首页 > 编程语言 > Java开发

【Java】两个排序后的数组A和B,其中A的末端有足够的缓冲容纳B。编写一个方法,将B合并入A并排序。

2015-07-22 10:36 645 查看
给定两个排序后的数组A和B,其中A的末端有足够的缓冲容纳B。编写一个方法,将B合并入A并排序。

看起来很像归并排序的最后一步,但还有些不同,由于A的末端足够容纳B,我们不需要再新建一个缓冲数组。

那么直接将A和B顺序比较插入相应位置即可,但如果从小到大比较,A的数据会被覆盖,由于A的末端是空的,我们可以从A和B最大的元素开始比较,从后往前依次插入.

要注意的是如果B的元素比A多,那么要逐一比较好几轮,才能把B的所有元素都插入A的正确位置。

反之如果A的元素比B多,则不需要这么做,因为A的元素已经在那里了,且最后一定是排好序的。

public class merge {
public static void mergeArrays(int[] a, int[] b, int lastA, int lastB) {
int round = (int)Math.ceil((double)lastB / lastA); //进一法取A和B要比较的轮数
int indexA = lastA - 1;
int indexB = lastB - 1;
int indexMerged = lastB + lastA - 1;
while (round >= 1) {
while(indexA >= 0 && indexB >= 0) {
if (a[indexA] >= b[indexB]) {
a[indexMerged--] = a[indexA--];
}
else {
a[indexMerged--] = b[indexB--];
}
}
round--;
indexA = lastA - 1;
}
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: