Copyright | Copyright (c) 1998-1999 2008 Chris Okasaki |
---|---|
License | MIT; see COPYRIGHT file for terms and conditions |
Maintainer | robdockins AT fastmail DOT fm |
Stability | stable |
Portability | GHC, Hugs (MPTC and FD) |
Safe Haskell | Safe-Inferred |
Language | Haskell2010 |
Data.Edison.Coll.UnbalancedSet
Description
Sets implemented as unbalanced binary search trees.
Synopsis
- data Set a
- empty :: Set a
- singleton :: a -> Set a
- fromSeq :: (Ord a, Sequence seq) => seq a -> Set a
- insert :: Ord a => a -> Set a -> Set a
- insertSeq :: (Ord a, Sequence seq) => seq a -> Set a -> Set a
- union :: Ord a => Set a -> Set a -> Set a
- unionSeq :: (Ord a, Sequence seq) => seq (Set a) -> Set a
- delete :: Ord a => a -> Set a -> Set a
- deleteAll :: Ord a => a -> Set a -> Set a
- deleteSeq :: (Ord a, Sequence seq) => seq a -> Set a -> Set a
- null :: Set a -> Bool
- size :: Set a -> Int
- member :: Ord a => a -> Set a -> Bool
- count :: Ord a => a -> Set a -> Int
- strict :: Set a -> Set a
- structuralInvariant :: Ord a => Set a -> Bool
- toSeq :: (Ord a, Sequence seq) => Set a -> seq a
- lookup :: Ord a => a -> Set a -> a
- lookupM :: (Ord a, MonadFail m) => a -> Set a -> m a
- lookupAll :: (Ord a, Sequence seq) => a -> Set a -> seq a
- lookupWithDefault :: Ord a => a -> a -> Set a -> a
- fold :: (a -> b -> b) -> b -> Set a -> b
- fold' :: (a -> b -> b) -> b -> Set a -> b
- fold1 :: (a -> a -> a) -> Set a -> a
- fold1' :: (a -> a -> a) -> Set a -> a
- filter :: Ord a => (a -> Bool) -> Set a -> Set a
- partition :: Ord a => (a -> Bool) -> Set a -> (Set a, Set a)
- strictWith :: (a -> b) -> Set a -> Set a
- deleteMin :: Ord a => Set a -> Set a
- deleteMax :: Ord a => Set a -> Set a
- unsafeInsertMin :: Ord a => a -> Set a -> Set a
- unsafeInsertMax :: Ord a => a -> Set a -> Set a
- unsafeFromOrdSeq :: (Ord a, Sequence seq) => seq a -> Set a
- unsafeAppend :: Ord a => Set a -> Set a -> Set a
- filterLT :: Ord a => a -> Set a -> Set a
- filterLE :: Ord a => a -> Set a -> Set a
- filterGT :: Ord a => a -> Set a -> Set a
- filterGE :: Ord a => a -> Set a -> Set a
- partitionLT_GE :: Ord a => a -> Set a -> (Set a, Set a)
- partitionLE_GT :: Ord a => a -> Set a -> (Set a, Set a)
- partitionLT_GT :: Ord a => a -> Set a -> (Set a, Set a)
- minView :: MonadFail m => Set a -> m (a, Set a)
- minElem :: Set a -> a
- maxView :: MonadFail m => Set a -> m (a, Set a)
- maxElem :: Set a -> a
- foldr :: (a -> b -> b) -> b -> Set a -> b
- foldr' :: (a -> b -> b) -> b -> Set a -> b
- foldl :: (b -> a -> b) -> b -> Set a -> b
- foldl' :: (b -> a -> b) -> b -> Set a -> b
- foldr1 :: (a -> a -> a) -> Set a -> a
- foldr1' :: (a -> a -> a) -> Set a -> a
- foldl1 :: (a -> a -> a) -> Set a -> a
- foldl1' :: (a -> a -> a) -> Set a -> a
- toOrdSeq :: (Ord a, Sequence seq) => Set a -> seq a
- unsafeMapMonotonic :: Ord a => (a -> a) -> Set a -> Set a
- intersection :: Ord a => Set a -> Set a -> Set a
- difference :: Ord a => Set a -> Set a -> Set a
- symmetricDifference :: Ord a => Set a -> Set a -> Set a
- properSubset :: Ord a => Set a -> Set a -> Bool
- subset :: Ord a => Set a -> Set a -> Bool
- fromSeqWith :: (Ord a, Sequence seq) => (a -> a -> a) -> seq a -> Set a
- insertWith :: Ord a => (a -> a -> a) -> a -> Set a -> Set a
- insertSeqWith :: (Ord a, Sequence seq) => (a -> a -> a) -> seq a -> Set a -> Set a
- unionl :: Ord a => Set a -> Set a -> Set a
- unionr :: Ord a => Set a -> Set a -> Set a
- unionWith :: Ord a => (a -> a -> a) -> Set a -> Set a -> Set a
- unionSeqWith :: (Ord a, Sequence seq) => (a -> a -> a) -> seq (Set a) -> Set a
- intersectionWith :: Ord a => (a -> a -> a) -> Set a -> Set a -> Set a
- moduleName :: String
Set type
Instances
(Ord a, Arbitrary a) => Arbitrary (Set a) Source # | |
(Ord a, CoArbitrary a) => CoArbitrary (Set a) Source # | |
Defined in Data.Edison.Coll.UnbalancedSet Methods coarbitrary :: Set a -> Gen b -> Gen b # | |
Ord a => Monoid (Set a) Source # | |
Ord a => Semigroup (Set a) Source # | |
(Ord a, Read a) => Read (Set a) Source # | |
(Ord a, Show a) => Show (Set a) Source # | |
Ord a => Eq (Set a) Source # | |
Ord a => Ord (Set a) Source # | |
Ord a => Coll (Set a) a Source # | |
Defined in Data.Edison.Coll.UnbalancedSet Methods toSeq :: Sequence seq => Set a -> seq a # lookupM :: MonadFail m => a -> Set a -> m a # lookupAll :: Sequence seq => a -> Set a -> seq a # lookupWithDefault :: a -> a -> Set a -> a # fold :: (a -> b -> b) -> b -> Set a -> b # fold' :: (a -> b -> b) -> b -> Set a -> b # fold1 :: (a -> a -> a) -> Set a -> a # fold1' :: (a -> a -> a) -> Set a -> a # filter :: (a -> Bool) -> Set a -> Set a # partition :: (a -> Bool) -> Set a -> (Set a, Set a) # strictWith :: (a -> b) -> Set a -> Set a # | |
Ord a => CollX (Set a) a Source # | |
Defined in Data.Edison.Coll.UnbalancedSet Methods fromSeq :: Sequence seq => seq a -> Set a # unionSeq :: Sequence seq => seq (Set a) -> Set a # insert :: a -> Set a -> Set a # insertSeq :: Sequence seq => seq a -> Set a -> Set a # delete :: a -> Set a -> Set a # deleteAll :: a -> Set a -> Set a # deleteSeq :: Sequence seq => seq a -> Set a -> Set a # member :: a -> Set a -> Bool # structuralInvariant :: Set a -> Bool # instanceName :: Set a -> String # | |
Ord a => OrdColl (Set a) a Source # | |
Defined in Data.Edison.Coll.UnbalancedSet Methods minView :: MonadFail m => Set a -> m (a, Set a) # maxView :: MonadFail m => Set a -> m (a, Set a) # foldr :: (a -> b -> b) -> b -> Set a -> b # foldr' :: (a -> b -> b) -> b -> Set a -> b # foldl :: (b -> a -> b) -> b -> Set a -> b # foldl' :: (b -> a -> b) -> b -> Set a -> b # foldr1 :: (a -> a -> a) -> Set a -> a # foldr1' :: (a -> a -> a) -> Set a -> a # foldl1 :: (a -> a -> a) -> Set a -> a # foldl1' :: (a -> a -> a) -> Set a -> a # toOrdSeq :: Sequence seq => Set a -> seq a # unsafeMapMonotonic :: (a -> a) -> Set a -> Set a # | |
Ord a => OrdCollX (Set a) a Source # | |
Defined in Data.Edison.Coll.UnbalancedSet Methods unsafeInsertMin :: a -> Set a -> Set a # unsafeInsertMax :: a -> Set a -> Set a # unsafeFromOrdSeq :: Sequence seq => seq a -> Set a # unsafeAppend :: Set a -> Set a -> Set a # filterLT :: a -> Set a -> Set a # filterLE :: a -> Set a -> Set a # filterGT :: a -> Set a -> Set a # filterGE :: a -> Set a -> Set a # partitionLT_GE :: a -> Set a -> (Set a, Set a) # partitionLE_GT :: a -> Set a -> (Set a, Set a) # partitionLT_GT :: a -> Set a -> (Set a, Set a) # | |
Ord a => OrdSet (Set a) a Source # | |
Defined in Data.Edison.Coll.UnbalancedSet | |
Ord a => OrdSetX (Set a) a Source # | |
Defined in Data.Edison.Coll.UnbalancedSet | |
Ord a => Set (Set a) a Source # | |
Defined in Data.Edison.Coll.UnbalancedSet Methods fromSeqWith :: Sequence seq => (a -> a -> a) -> seq a -> Set a # insertWith :: (a -> a -> a) -> a -> Set a -> Set a # insertSeqWith :: Sequence seq => (a -> a -> a) -> seq a -> Set a -> Set a # unionl :: Set a -> Set a -> Set a # unionr :: Set a -> Set a -> Set a # unionWith :: (a -> a -> a) -> Set a -> Set a -> Set a # unionSeqWith :: Sequence seq => (a -> a -> a) -> seq (Set a) -> Set a # intersectionWith :: (a -> a -> a) -> Set a -> Set a -> Set a # | |
Ord a => SetX (Set a) a Source # | |
CollX operations
Coll operations
lookupWithDefault :: Ord a => a -> a -> Set a -> a Source #
strictWith :: (a -> b) -> Set a -> Set a Source #
OrdCollX operations
OrdColl operations
SetX operations
Set operations
Documentation
moduleName :: String Source #