priorityqueue

package
v4.2.3 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 11, 2023 License: MIT Imports: 2 Imported by: 1

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type BinHeap

type BinHeap[T Item] struct {
	// contains filtered or unexported fields
}

func NewBinHeap

func NewBinHeap[T Item](maxLen uint64) *BinHeap[T]

func (*BinHeap[T]) ExtractMin

func (bh *BinHeap[T]) ExtractMin() T

func (*BinHeap[T]) Insert

func (bh *BinHeap[T]) Insert(item T)

func (*BinHeap[T]) Len

func (bh *BinHeap[T]) Len() uint64

func (*BinHeap[T]) PeekPriority added in v4.1.0

func (bh *BinHeap[T]) PeekPriority() int64

PeekPriority returns the highest priority

func (*BinHeap[T]) Remove added in v4.2.0

func (bh *BinHeap[T]) Remove(id string) []T

Remove removes all elements with the provided ID and returns the slice with them

type Item

type Item interface {
	// Priority returns the Item's priority to sort
	Priority() int64
	// ID of the item
	ID() string
}

Item represents binary heap item

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL