What is the complexity of Java's PriorityQueue constructor with a Collection
?
I used the constructor:
PriorityQueue(Collection<? extends E> c)
Is the complexity O(n) or O(n*log(n))?
What is the complexity of Java's PriorityQueue constructor with a Collection
?
I used the constructor:
PriorityQueue(Collection<? extends E> c)
Is the complexity O(n) or O(n*log(n))?
The time complexity to initialize a
PriorityQueue
from a collection, even an unsorted one, is O(n). Internally this uses a procedure calledsiftDown()
to "heapify" an array in-place. (This is also called pushdown in the literature.)This is counterintuitive. It seems like inserting an element into a heap is O(log n) so inserting n elements results in O(n log n) complexity. This is true if you insert the elements one at a time. (Internally, inserting an individual element does this using
siftUp()
.)Heapifying an individual element is certainly O(log n), but the "trick" of
siftDown()
is that as each element is processed, the number of elements that it has to be sifted past is continually decreasing. So the total complexity isn't n elements times log(n); it's the sum of n terms of the decreasing cost of sifting past the remaining elements.See this answer, and see also this article that works through the math.
The complexity can't be
O(log(n))
because to processn
elements, the complexity has to be at leastO(n)
.However, the
PriorityQueue(Collection c)
constructor checks whether the collection is aSortedSet
, aPriorityQueue
or a normalCollection
and performs the initialization differently. If the parameter is aSortedSet
or aPriorityQueue
the complexity isO(n)
(it's implemented as an array copy). When using anotherCollection
it looks to beO(n log(n))
.