1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
|
module Validity.PQueue.Min
( validShape
, validSize
, validOrder
) where
import Data.PQueue.Internals
import qualified BinomialQueue.Internals as BQ
import qualified Validity.BinomialQueue as VBQ
validShape :: MinQueue a -> Bool
validShape Empty = True
validShape (MinQueue _ _ f) = VBQ.validShape f
validSize :: MinQueue a -> Bool
validSize Empty = True
validSize (MinQueue sz _ f) = sz == BQ.size f + 1
validOrder :: Ord a => MinQueue a -> Bool
validOrder Empty = True
validOrder (MinQueue _sz a f) = VBQ.precedesProperly a f
|