it.unimi.dsi.fastutil.ints.IntArrayPriorityQueueTest Maven / Gradle / Ivy
The newest version!
package it.unimi.dsi.fastutil.ints;
import static org.junit.Assert.assertEquals;
import it.unimi.dsi.fastutil.io.BinIO;
import java.io.File;
import java.io.IOException;
import org.junit.Test;
@SuppressWarnings("deprecation")
public class IntArrayPriorityQueueTest {
@Test
public void testEnqueueDequeue() {
IntArrayPriorityQueue q = new IntArrayPriorityQueue();
IntHeapPriorityQueue h = new IntHeapPriorityQueue();
for(int i = 0; i < 100; i++) {
q.enqueue(i);
h.enqueue(i);
}
for(int i = 0; i < 100; i++) {
assertEquals(h.first(), q.first());
assertEquals(h.dequeue(), q.dequeue());
}
q = new IntArrayPriorityQueue(10);
h.clear();
for(int i = 0; i < 100; i++) {
q.enqueue(i);
h.enqueue(i);
}
for(int i = 0; i < 100; i++) {
assertEquals(h.first(), q.first());
assertEquals(h.dequeue(), q.dequeue());
}
q = new IntArrayPriorityQueue(200);
h.clear();
for(int i = 0; i < 100; i++) {
q.enqueue(i);
h.enqueue(i);
}
for(int i = 0; i < 100; i++) {
assertEquals(h.first(), q.first());
assertEquals(h.dequeue(), q.dequeue());
}
}
@Test
public void testEnqueueDequeueComp() {
IntArrayPriorityQueue q = new IntArrayPriorityQueue(IntComparators.OPPOSITE_COMPARATOR);
IntHeapPriorityQueue h = new IntHeapPriorityQueue(IntComparators.OPPOSITE_COMPARATOR);
for(int i = 0; i < 100; i++) {
q.enqueue(i);
h.enqueue(i);
}
for(int i = 0; i < 100; i++) {
assertEquals(h.first(), q.first());
assertEquals(h.dequeue(), q.dequeue());
}
q = new IntArrayPriorityQueue(10, IntComparators.OPPOSITE_COMPARATOR);
h.clear();
for(int i = 0; i < 100; i++) {
q.enqueue(i);
h.enqueue(i);
}
for(int i = 0; i < 100; i++) {
assertEquals(h.first(), q.first());
assertEquals(h.dequeue(), q.dequeue());
}
q = new IntArrayPriorityQueue(200, IntComparators.OPPOSITE_COMPARATOR);
h.clear();
for(int i = 0; i < 100; i++) {
q.enqueue(i);
h.enqueue(i);
}
for(int i = 0; i < 100; i++) {
assertEquals(h.first(), q.first());
assertEquals(h.dequeue(), q.dequeue());
}
}
@Test
public void testMix() {
IntArrayPriorityQueue q = new IntArrayPriorityQueue();
IntHeapPriorityQueue h = new IntHeapPriorityQueue();
for(int i = 0; i < 200; i++) {
for(int j = 0; j < 20; j++) {
q.enqueue(j + i * 20);
h.enqueue(j + i * 20);
}
for(int j = 0; j < 10; j++) assertEquals(h.dequeueInt(), q.dequeueInt());
}
q = new IntArrayPriorityQueue(10);
h = new IntHeapPriorityQueue();
for(int i = 0; i < 200; i++) {
for(int j = 0; j < 20; j++) {
q.enqueue(j + i * -20);
h.enqueue(j + i * -20);
q.first();
}
for(int j = 0; j < 10; j++) assertEquals(h.dequeueInt(), q.dequeueInt());
}
q = new IntArrayPriorityQueue(200);
h = new IntHeapPriorityQueue();
for(int i = 0; i < 200; i++) {
for(int j = 0; j < 20; j++) {
q.enqueue(j + i * 20);
h.enqueue(j + i * 20);
}
for(int j = 0; j < 10; j++) assertEquals(h.dequeueInt(), q.dequeueInt());
}
}
@Test
public void testMixComp() {
IntArrayPriorityQueue q = new IntArrayPriorityQueue(IntComparators.OPPOSITE_COMPARATOR);
IntHeapPriorityQueue h = new IntHeapPriorityQueue(IntComparators.OPPOSITE_COMPARATOR);
for(int i = 0; i < 200; i++) {
for(int j = 0; j < 20; j++) {
q.enqueue(j + i * 20);
h.enqueue(j + i * 20);
}
for(int j = 0; j < 10; j++) assertEquals(h.dequeueInt(), q.dequeueInt());
}
q = new IntArrayPriorityQueue(10, IntComparators.OPPOSITE_COMPARATOR);
h = new IntHeapPriorityQueue(IntComparators.OPPOSITE_COMPARATOR);
for(int i = 0; i < 200; i++) {
for(int j = 0; j < 20; j++) {
q.enqueue(j + i * -20);
h.enqueue(j + i * -20);
q.first();
}
for(int j = 0; j < 10; j++) assertEquals(h.dequeueInt(), q.dequeueInt());
}
q = new IntArrayPriorityQueue(200, IntComparators.OPPOSITE_COMPARATOR);
h = new IntHeapPriorityQueue(IntComparators.OPPOSITE_COMPARATOR);
for(int i = 0; i < 200; i++) {
for(int j = 0; j < 20; j++) {
q.enqueue(j + i * 20);
h.enqueue(j + i * 20);
}
for(int j = 0; j < 10; j++) assertEquals(h.dequeueInt(), q.dequeueInt());
}
}
@Test
public void testSerialize() throws IOException, ClassNotFoundException {
IntArrayPriorityQueue q = new IntArrayPriorityQueue();
for(int i = 0; i < 100; i++) q.enqueue(i);
File file = File.createTempFile(getClass().getPackage().getName() + "-", "-tmp");
file.deleteOnExit();
BinIO.storeObject(q, file);
IntArrayPriorityQueue r = (IntArrayPriorityQueue)BinIO.loadObject(file);
file.delete();
for(int i = 0; i < 100; i++) {
assertEquals(q.first(), r.first());
assertEquals(q.dequeue(), r.dequeue());
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy