【发布时间】:2014-05-20 15:08:28
【问题描述】:
如何使 print_queue 在 Java 中正常工作?这是我自己实现的队列。
使用Iterator() 可以正常工作,只是它以随机顺序打印数字。
package data_structures_java ;
import java.util.Iterator;
import java.util.PriorityQueue ;
import java.util.* ;
public class Queue_implementation {
PriorityQueue<Integer> actual_queue ;
public Queue_implementation(){
actual_queue = new PriorityQueue<Integer>() ;
}
public void add(int num){
actual_queue.add(num) ;
}
public int remove(){
return actual_queue.remove() ;
}
public int peek(){
if( actual_queue.isEmpty()) return -1 ;
else return actual_queue.peek() ;
}
public int element(){
return actual_queue.element() ;
}
public void print_queue(){
PriorityQueue<Integer>copy = new PriorityQueue<Integer>();
copy.addAll(actual_queue) ;
Iterator<Integer> through = actual_queue.iterator() ;
while(through.hasNext() ) {
System.out.print(through.next() + " ") ;
}
System.out.println() ;
actual_queue.addAll(copy) ;
}
public static void main(String[] args) {
Queue_implementation x = new Queue_implementation() ;
x.add(10) ;
x.add(9) ;
x.add(8) ;
x.add(7) ;
x.add(6) ;
x.print_queue() ;
}
}
我尝试使用toArray(),但它返回Object[],我不知道如何遍历:
Object[] queue_object_array = x.toArray() ;
Arrays.sort(queue_object_array) ;
【问题讨论】:
-
您的队列应该是队列还是优先队列?他们做两件不同的事情。
-
@WillNewton,实际上只是排队,但我正在使用来自 java api 的 std.priority 队列
标签: java queue priority-queue