Safe Haskell | None |
---|---|
Language | GHC2021 |
Synopsis
- type RMQ a = SparseTable Min a
- buildRMQ :: (Unbox a, Ord a) => Vector a -> RMQ a
- readRMQ :: Unbox a => RMQ a -> Int -> a
- queryMin :: (Unbox a, Ord a) => RMQ a -> Int -> Int -> a
- newtype SparseTable (f :: Type -> Type) a = SparseTable {
- getSparseTable :: Vector (Vector a)
- buildSparseTable :: forall (f :: Type -> Type) a. (Unbox a, Semigroup (f a), Coercible (f a) a) => Vector a -> SparseTable f a
- readSparseTable :: forall a (f :: Type -> Type). Unbox a => SparseTable f a -> Int -> a
- querySparseTable :: forall (f :: Type -> Type) a. (Unbox a, Semigroup (f a), Coercible (f a) a) => SparseTable f a -> Int -> Int -> a
Documentation
type RMQ a = SparseTable Min a Source #
newtype SparseTable (f :: Type -> Type) a Source #
SparseTable | |
|
Instances
(Show a, Unbox a) => Show (SparseTable f a) Source # | |
Defined in Data.SparseTable showsPrec :: Int -> SparseTable f a -> ShowS # show :: SparseTable f a -> String # showList :: [SparseTable f a] -> ShowS # | |
(Unbox a, Eq a) => Eq (SparseTable f a) Source # | |
Defined in Data.SparseTable (==) :: SparseTable f a -> SparseTable f a -> Bool # (/=) :: SparseTable f a -> SparseTable f a -> Bool # |
buildSparseTable :: forall (f :: Type -> Type) a. (Unbox a, Semigroup (f a), Coercible (f a) a) => Vector a -> SparseTable f a Source #
readSparseTable :: forall a (f :: Type -> Type). Unbox a => SparseTable f a -> Int -> a Source #
O(1)
querySparseTable :: forall (f :: Type -> Type) a. (Unbox a, Semigroup (f a), Coercible (f a) a) => SparseTable f a -> Int -> Int -> a Source #
append[l..r)
O(1)