mirror of
https://github.com/emirpasic/gods.git
synced 2026-06-15 16:16:35 +03:00
14f714261f
* Generics migration This attempts to migrate this library in the least invasive way by preserving as much of the original API as possible. It does not change the tests in a meaningful way nor does it attempt to upgrade any logic that can be simplified or improved with generics. This is purely an API migration, and still requires a lot of additional work to be fully ready. * Fix a few broken tests around serialization * Add v2 suffix * Temporarily change mod name for testing * Rename module to /v2
42 lines
1.3 KiB
Go
42 lines
1.3 KiB
Go
// Copyright (c) 2015, Emir Pasic. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package main
|
|
|
|
import (
|
|
"cmp"
|
|
|
|
"github.com/emirpasic/gods/v2/trees/binaryheap"
|
|
)
|
|
|
|
// BinaryHeapExample to demonstrate basic usage of BinaryHeap
|
|
func main() {
|
|
|
|
// Min-heap
|
|
heap := binaryheap.New[int]() // empty (min-heap)
|
|
heap.Push(2) // 2
|
|
heap.Push(3) // 2, 3
|
|
heap.Push(1) // 1, 3, 2
|
|
heap.Values() // 1, 3, 2
|
|
_, _ = heap.Peek() // 1,true
|
|
_, _ = heap.Pop() // 1, true
|
|
_, _ = heap.Pop() // 2, true
|
|
_, _ = heap.Pop() // 3, true
|
|
_, _ = heap.Pop() // nil, false (nothing to pop)
|
|
heap.Push(1) // 1
|
|
heap.Clear() // empty
|
|
heap.Empty() // true
|
|
heap.Size() // 0
|
|
|
|
// Max-heap
|
|
inverseIntComparator := func(a, b int) int {
|
|
return -cmp.Compare(a, b)
|
|
}
|
|
heap = binaryheap.NewWith(inverseIntComparator) // empty (min-heap)
|
|
heap.Push(2) // 2
|
|
heap.Push(3) // 3, 2
|
|
heap.Push(1) // 3, 2, 1
|
|
heap.Values() // 3, 2, 1
|
|
}
|