作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这是我的代码:
void mergeHelper(Queue<T> input1, Queue<T> input2, Queue<T> output) {
// TODO 4
if(!input1.isEmpty())
{
T ip1 = input1.dequeue();
if(!input2.isEmpty())
{
T ip2 = input2.dequeue();
if(ip1.compareTo(ip2)<=0)
output.enqueue(ip1);
else
output.enqueue(ip2);
}
else
{
output.enqueue(ip1);
}
mergeHelper(input1, input2, output);
}
else if(!input2.isEmpty())
{
T ip2 = input2.dequeue();
if(!input1.isEmpty())
{
T ip1 = input1.dequeue();
if(ip1.compareTo(ip2)<=0)
output.enqueue(ip1);
else
output.enqueue(ip2);
}
else
{
output.enqueue(ip2);
}
mergeHelper(input1, input2, output);
}
}
这是一个临时驱动程序:
public class MergeDriver {
public static void main(String[] args) {
MergeSorter<Integer> ms = new MergeSorter<>();
Queue<Integer> one = new Queue<>();
Queue<Integer> two = new Queue<>();
one.enqueue(new Integer(2));
two.enqueue(new Integer(1));
Queue<Integer> res = ms.merge(one, two);
System.out.println("The size of res is: "+ res.size());
System.out.println("The value stored is: ");
while(!res.isEmpty())
System.out.println((int)res.dequeue());
}
}
只有 1 个被添加到输出队列中,其余的则没有。
生成的队列大小始终为 1,并且仅将最小的元素添加到队列中。我究竟做错了什么?
最佳答案
您的算法不正确,因为它将两个项目出队进行比较,但仅将其中一项添加回输出。
您可以使用 peek()
来修复此问题出队之前的方法,比较结果,然后才将两个元素中较小的一个出队,并将其移动到输出中。
关于java - 合并排序: Why does my merge method only add one number to the queue?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44658600/
我是一名优秀的程序员,十分优秀!