Add useful functions to MultiSortedList
This commit is contained in:
parent
c6080ae3fa
commit
4b91481e96
@ -44,6 +44,10 @@ class MultiSortedList<E> constructor(
|
|||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fun contains(element: E, comparator: Comparator<E>) =
|
||||||
|
if (comparator == this.comparator) contains(element)
|
||||||
|
else extraLists[comparator]!!.contains(element)
|
||||||
|
|
||||||
override fun remove(element: E): Boolean {
|
override fun remove(element: E): Boolean {
|
||||||
if (super.remove(element)) {
|
if (super.remove(element)) {
|
||||||
extraLists.values.forEach {
|
extraLists.values.forEach {
|
||||||
@ -90,6 +94,36 @@ class MultiSortedList<E> constructor(
|
|||||||
if (comparator == this.comparator) this[index]
|
if (comparator == this.comparator) this[index]
|
||||||
else extraLists[comparator]!![index]
|
else extraLists[comparator]!![index]
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get all contiguous elements that match a comparison
|
||||||
|
* @return Iterable object of all matching elements, or null if none exist
|
||||||
|
*/
|
||||||
|
fun getAll(comparator: Comparator<in E>, comparison: (E) -> Int): Iterable<E>? {
|
||||||
|
var index = binSearch(comparator, comparison)
|
||||||
|
if (index < 0) return null
|
||||||
|
|
||||||
|
val result = LinkedList<E>()
|
||||||
|
|
||||||
|
var element: E
|
||||||
|
do {
|
||||||
|
element = get(index++, comparator)
|
||||||
|
if (comparison(element) != 0)
|
||||||
|
break
|
||||||
|
|
||||||
|
result += element
|
||||||
|
} while (index < size)
|
||||||
|
|
||||||
|
return result
|
||||||
|
}
|
||||||
|
|
||||||
|
fun findValueOrNull(comparator: Comparator<in E>, comparison: (E) -> Int): E? {
|
||||||
|
val index = binSearch(comparator, comparison)
|
||||||
|
|
||||||
|
if (index < 0) return null
|
||||||
|
|
||||||
|
return get(index, comparator)
|
||||||
|
}
|
||||||
|
|
||||||
fun binSearch(element: E, comparator: Comparator<in E>) =
|
fun binSearch(element: E, comparator: Comparator<in E>) =
|
||||||
if (comparator == this.comparator) binarySearch(element, comparator)
|
if (comparator == this.comparator) binarySearch(element, comparator)
|
||||||
else extraLists[comparator]!!.binarySearch(element, comparator)
|
else extraLists[comparator]!!.binarySearch(element, comparator)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user