12
val maxHeap = scala.collection.mutable.PriorityQueue[Int] //Gives MaxHeap

What is the most concise and efficient way to use Ordering to turn a PriorityQueue into a minHeap?

user3335040
  • 649
  • 1
  • 7
  • 17

2 Answers2

19

You'll have to define your own Ordering :

scala> object MinOrder extends Ordering[Int] {
         def compare(x:Int, y:Int) = y compare x
       }
defined object MinOrder

Then use that when creating the heap :

scala> val minHeap = scala.collection.mutable.PriorityQueue.empty(MinOrder)
minHeap: scala.collection.mutable.PriorityQueue[Int] = PriorityQueue()

scala> minHeap.ord
res1: Ordering[Int] = MinOrder$@158ac84e
Marth
  • 23,920
  • 3
  • 60
  • 72
  • 12
    I think you don't even need to create your own Ordering, you can use method .reverse of an already existing one: Ordering[Int].reverse – nachinius Oct 30 '16 at 23:54
  • 11
    for completion val minHeap = scala.collection.mutable.PriorityQueue.empty(Ordering[Int].reverse) https://codebunk.com/pb/788100787 – nachinius Oct 31 '16 at 00:01
2

Update August 2016: you can consider the proposal chrisokasaki/scads/scala/heapTraits.scala from Chris Okasaki (chrisokasaki).

That proposal illustrates the "not-so-easy" part of an Heap:

Proof of concept for typesafe heaps with a merge operation.
Here, "typesafe" means that the interface will never allow different orderings to be mixed within the same heap.
In particular,

  • when adding an element to an existing heap, that insertion cannot involve an ordering different from the one used to create the existing heap, and
  • when merging two existing heaps, the heaps are guaranteed to have been created with the same ordering.

See its design.

val h1 = LeftistHeap.Min.empty[Int] // an empty min-heap of integers
VonC
  • 1,262,500
  • 529
  • 4,410
  • 5,250