Class LongInterval
java.lang.Object
java.util.AbstractCollection<Long>
it.unimi.dsi.fastutil.longs.AbstractLongCollection
it.unimi.dsi.fastutil.longs.AbstractLongSet
it.unimi.dsi.fastutil.longs.AbstractLongSortedSet
it.unimi.dsi.util.LongInterval
- All Implemented Interfaces:
it.unimi.dsi.fastutil.longs.LongBidirectionalIterable, it.unimi.dsi.fastutil.longs.LongCollection, it.unimi.dsi.fastutil.longs.LongIterable, it.unimi.dsi.fastutil.longs.LongSet, it.unimi.dsi.fastutil.longs.LongSortedSet, Serializable, Cloneable, Iterable<Long>, Collection<Long>, SequencedCollection<Long>, SequencedSet<Long>, Set<Long>, SortedSet<Long>
public final class LongInterval
extends it.unimi.dsi.fastutil.longs.AbstractLongSortedSet
implements it.unimi.dsi.fastutil.longs.LongSortedSet, Serializable
An interval of longs. See
Interval for details.- See Also:
-
Field Summary
Fields -
Constructor Summary
ConstructorsModifierConstructorDescriptionprotectedLongInterval(long left, long right) Builds an interval with given extremes. -
Method Summary
Modifier and TypeMethodDescriptionit.unimi.dsi.fastutil.longs.LongComparatorintcompareTo(int x) Compares this interval to an integer.intcompareTo(int x, int radius) Compares this interval to an integer with a specified radius.intcompareTo(int x, int leftRadius, int rightRadius) Compares this interval to an integer with specified left and right radii.booleancontains(int x) Checks whether this interval contains the specified integer.booleancontains(int x, int radius) Checks whether this interval would contain the specified integer if enlarged in both directions by the specified radius.booleancontains(int x, int leftRadius, int rightRadius) Checks whether this interval would contain the specified integer if enlarged in each direction with the respective radius.booleancontains(LongInterval interval) Checks whether this interval contains the specified interval.booleanChecks whether this interval is equal to another set of integers.longinthashCode()it.unimi.dsi.fastutil.longs.LongSortedSetheadSet(long to) it.unimi.dsi.fastutil.longs.LongBidirectionalIteratoriterator()Returns an iterator over the integers in this interval.it.unimi.dsi.fastutil.longs.LongBidirectionalIteratoriterator(long from) Returns an iterator over the integers in this interval larger than or equal to a given integer.longlastLong()longlength()Returns the interval length, that is, the number of integers contained in the interval.intsize()An alias forlength()miminised withInteger.MAX_VALUE.longsize64()An alias forlength().it.unimi.dsi.fastutil.longs.LongSortedSetsubSet(long from, long to) it.unimi.dsi.fastutil.longs.LongSortedSettailSet(long from) toString()static LongIntervalvalueOf(long point) Returns a one-point interval.static LongIntervalvalueOf(long left, long right) Returns an interval with given extremes.Methods inherited from class it.unimi.dsi.fastutil.longs.AbstractLongSet
rem, removeMethods inherited from class it.unimi.dsi.fastutil.longs.AbstractLongCollection
add, add, addAll, addAll, contains, contains, containsAll, containsAll, forEach, remove, removeAll, removeAll, removeIf, retainAll, retainAll, toArray, toLongArray, toLongArrayMethods inherited from class AbstractCollection
clear, isEmpty, toArray, toArrayMethods inherited from interface Collection
toArrayMethods inherited from interface it.unimi.dsi.fastutil.longs.LongCollection
add, addAll, contains, containsAll, longIterator, longParallelStream, longSpliterator, longStream, parallelStream, removeAll, removeIf, removeIf, removeIf, retainAll, stream, toArray, toLongArray, toLongArrayMethods inherited from interface it.unimi.dsi.fastutil.longs.LongIterable
forEach, forEach, forEachMethods inherited from interface it.unimi.dsi.fastutil.longs.LongSet
add, contains, rem, remove, removeMethods inherited from interface it.unimi.dsi.fastutil.longs.LongSortedSet
first, headSet, last, spliterator, subSet, tailSetMethods inherited from interface Set
add, addAll, clear, contains, containsAll, isEmpty, remove, removeAll, retainAll, toArray, toArrayMethods inherited from interface SortedSet
addFirst, addLast, getFirst, getLast, removeFirst, removeLast, reversed
-
Field Details
-
left
public final long leftThe left extreme of the interval. -
right
public final long rightThe right extreme of the interval.
-
-
Constructor Details
-
LongInterval
protected LongInterval(long left, long right) Builds an interval with given extremes.You cannot generate an empty interval with this constructor. Use
Intervals.EMPTY_INTERVALinstead.- Parameters:
left- the left extreme.right- the right extreme (which must be greater than or equal to the left extreme).
-
-
Method Details
-
valueOf
Returns an interval with given extremes.You cannot obtain an empty interval with this factory method. Use
Intervals.EMPTY_INTERVALinstead.- Parameters:
left- the left extreme.right- the right extreme (which must be greater than or equal to the left extreme).- Returns:
- an interval with the given extremes.
-
valueOf
Returns a one-point interval.You cannot obtain an empty interval with this factory method. Use
Intervals.EMPTY_INTERVALinstead.- Parameters:
point- a point.- Returns:
- a one-point interval
-
length
public long length()Returns the interval length, that is, the number of integers contained in the interval.- Returns:
- the interval length.
-
size
public int size()An alias forlength()miminised withInteger.MAX_VALUE.- Specified by:
sizein interfaceCollection<Long>- Specified by:
sizein interfaceSet<Long>- Specified by:
sizein classAbstractCollection<Long>- Returns:
- the interval length minimised with
Integer.MAX_VALUE.
-
size64
-
iterator
public it.unimi.dsi.fastutil.longs.LongBidirectionalIterator iterator()Returns an iterator over the integers in this interval.- Specified by:
iteratorin interfaceCollection<Long>- Specified by:
iteratorin interfaceIterable<Long>- Specified by:
iteratorin interfaceit.unimi.dsi.fastutil.longs.LongBidirectionalIterable- Specified by:
iteratorin interfaceit.unimi.dsi.fastutil.longs.LongCollection- Specified by:
iteratorin interfaceit.unimi.dsi.fastutil.longs.LongIterable- Specified by:
iteratorin interfaceit.unimi.dsi.fastutil.longs.LongSet- Specified by:
iteratorin interfaceit.unimi.dsi.fastutil.longs.LongSortedSet- Specified by:
iteratorin interfaceSet<Long>- Specified by:
iteratorin classit.unimi.dsi.fastutil.longs.AbstractLongSortedSet- Returns:
- an integer iterator over the elements in this interval.
-
iterator
public it.unimi.dsi.fastutil.longs.LongBidirectionalIterator iterator(long from) Returns an iterator over the integers in this interval larger than or equal to a given integer.- Specified by:
iteratorin interfaceit.unimi.dsi.fastutil.longs.LongSortedSet- Parameters:
from- the starting integer.- Returns:
- an integer iterator over the elements in this interval.
-
contains
-
contains
Checks whether this interval contains the specified interval.- Parameters:
interval- an interval.- Returns:
- whether this interval contains (as a set)
interval.
-
contains
public boolean contains(int x, int radius) Checks whether this interval would contain the specified integer if enlarged in both directions by the specified radius. -
contains
public boolean contains(int x, int leftRadius, int rightRadius) Checks whether this interval would contain the specified integer if enlarged in each direction with the respective radius. directions by the specified radius. -
compareTo
-
compareTo
public int compareTo(int x, int radius) Compares this interval to an integer with a specified radius. -
compareTo
public int compareTo(int x, int leftRadius, int rightRadius) Compares this interval to an integer with specified left and right radii.- Parameters:
x- an integer.leftRadius- the left radius.rightRadius- the right radius.- Returns:
- a negative integer, zero, or a positive integer as
xis positioned at the left, belongs, or is positioned to the right of this interval enlarged byleftRadiuson the left andrightRadiusin the right, that is, asx<left−leftRadius,left−leftRadius≤x≤right+rightRadiusorright+rightRadius<x.
-
comparator
public it.unimi.dsi.fastutil.longs.LongComparator comparator()- Specified by:
comparatorin interfaceit.unimi.dsi.fastutil.longs.LongSortedSet- Specified by:
comparatorin interfaceSortedSet<Long>
-
headSet
public it.unimi.dsi.fastutil.longs.LongSortedSet headSet(long to) - Specified by:
headSetin interfaceit.unimi.dsi.fastutil.longs.LongSortedSet
-
tailSet
public it.unimi.dsi.fastutil.longs.LongSortedSet tailSet(long from) - Specified by:
tailSetin interfaceit.unimi.dsi.fastutil.longs.LongSortedSet
-
subSet
public it.unimi.dsi.fastutil.longs.LongSortedSet subSet(long from, long to) - Specified by:
subSetin interfaceit.unimi.dsi.fastutil.longs.LongSortedSet
-
firstLong
public long firstLong()- Specified by:
firstLongin interfaceit.unimi.dsi.fastutil.longs.LongSortedSet
-
lastLong
public long lastLong()- Specified by:
lastLongin interfaceit.unimi.dsi.fastutil.longs.LongSortedSet
-
toString
- Overrides:
toStringin classit.unimi.dsi.fastutil.longs.AbstractLongCollection
-
hashCode
-
equals
Checks whether this interval is equal to another set of integers.- Specified by:
equalsin interfaceCollection<Long>- Specified by:
equalsin interfaceSet<Long>- Overrides:
equalsin classit.unimi.dsi.fastutil.longs.AbstractLongSet- Parameters:
o- an object.- Returns:
- true if
ois an ordered set of integer containing the same element of this interval in the same order, or ifois a set of integers containing the same elements of this interval.
-