Add useful functions to MultiSortedList
This commit is contained in:
parent
c6080ae3fa
commit
4b91481e96
@ -44,6 +44,10 @@ class MultiSortedList<E> constructor(
|
||||
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 {
|
||||
if (super.remove(element)) {
|
||||
extraLists.values.forEach {
|
||||
@ -90,6 +94,36 @@ class MultiSortedList<E> constructor(
|
||||
if (comparator == this.comparator) this[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>) =
|
||||
if (comparator == this.comparator) binarySearch(element, comparator)
|
||||
else extraLists[comparator]!!.binarySearch(element, comparator)
|
||||
|
Loading…
x
Reference in New Issue
Block a user