summaryrefslogtreecommitdiff
path: root/src/main/java/utils/VSPriorityQueue.java
blob: d70635231601b8181b3d4b03e9f1f25ced30e565 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
package utils;

import java.util.PriorityQueue;

/**
 * The class VSPriorityQueue. This class is the same like the standard
 * VSPriorityQueue of the Java API. It only overrides the get(int) method.
 *
 * @author Paul C. Buetow
 */
public final class VSPriorityQueue<T> extends PriorityQueue<T> {
    /** The serial version uid */
    private static final long serialVersionUID = 1L;

    /**
     * Gets the specific element. If the index is out of bounds, it will return
     * null.
     *
     * @param index the index
     *
     * @return the element, or null, if out of bounds
     */
    public T get(int index) {
        int i = 0;

        for (T t : this)
            if (i++ == index)
                return t;

        return null;
    }
}