2015-12-15 11:47:04 -08:00
|
|
|
// collections/PriorityQueueDemo.java
|
2016-12-30 17:23:13 -08:00
|
|
|
// (c)2017 MindView LLC: see Copyright.txt
|
2015-11-15 15:51:35 -08:00
|
|
|
// We make no guarantees that this code is fit for any purpose.
|
2016-09-23 13:23:35 -06:00
|
|
|
// Visit http://OnJava8.com for more book information.
|
2015-06-15 17:47:35 -07:00
|
|
|
import java.util.*;
|
|
|
|
|
|
|
|
public class PriorityQueueDemo {
|
|
|
|
public static void main(String[] args) {
|
|
|
|
PriorityQueue<Integer> priorityQueue =
|
|
|
|
new PriorityQueue<>();
|
|
|
|
Random rand = new Random(47);
|
|
|
|
for(int i = 0; i < 10; i++)
|
|
|
|
priorityQueue.offer(rand.nextInt(i + 10));
|
|
|
|
QueueDemo.printQ(priorityQueue);
|
|
|
|
|
|
|
|
List<Integer> ints = Arrays.asList(25, 22, 20,
|
|
|
|
18, 14, 9, 3, 1, 1, 2, 3, 9, 14, 18, 21, 23, 25);
|
|
|
|
priorityQueue = new PriorityQueue<>(ints);
|
|
|
|
QueueDemo.printQ(priorityQueue);
|
|
|
|
priorityQueue = new PriorityQueue<>(
|
|
|
|
ints.size(), Collections.reverseOrder());
|
|
|
|
priorityQueue.addAll(ints);
|
|
|
|
QueueDemo.printQ(priorityQueue);
|
|
|
|
|
|
|
|
String fact = "EDUCATION SHOULD ESCHEW OBFUSCATION";
|
2017-05-10 11:45:39 -06:00
|
|
|
List<String> strings =
|
|
|
|
Arrays.asList(fact.split(""));
|
2015-06-15 17:47:35 -07:00
|
|
|
PriorityQueue<String> stringPQ =
|
|
|
|
new PriorityQueue<>(strings);
|
|
|
|
QueueDemo.printQ(stringPQ);
|
|
|
|
stringPQ = new PriorityQueue<>(
|
|
|
|
strings.size(), Collections.reverseOrder());
|
|
|
|
stringPQ.addAll(strings);
|
|
|
|
QueueDemo.printQ(stringPQ);
|
|
|
|
|
|
|
|
Set<Character> charSet = new HashSet<>();
|
|
|
|
for(char c : fact.toCharArray())
|
|
|
|
charSet.add(c); // Autoboxing
|
|
|
|
PriorityQueue<Character> characterPQ =
|
|
|
|
new PriorityQueue<>(charSet);
|
|
|
|
QueueDemo.printQ(characterPQ);
|
|
|
|
}
|
2015-09-07 11:44:36 -06:00
|
|
|
}
|
|
|
|
/* Output:
|
2015-06-15 17:47:35 -07:00
|
|
|
0 1 1 1 1 1 3 5 8 14
|
|
|
|
1 1 2 3 3 9 9 14 14 18 18 20 21 22 23 25 25
|
|
|
|
25 25 23 22 21 20 18 18 14 14 9 9 3 3 2 1 1
|
2017-05-10 11:45:39 -06:00
|
|
|
A A B C C C D D E E E F H H I I L N N O O O O S S
|
|
|
|
S T T U U U W
|
|
|
|
W U U U T T S S S O O O O N N L I I H H F E E E D D C C
|
|
|
|
C B A A
|
2015-06-15 17:47:35 -07:00
|
|
|
A B C D E F H I L N O S T U W
|
2015-09-07 11:44:36 -06:00
|
|
|
*/
|