[Haskell-cafe] how to select random elements of a Data.Set?
Christian Maeder
Christian.Maeder at dfki.de
Fri Jul 20 16:37:15 CEST 2012
Am 20.07.2012 15:24, schrieb jwaldmann:
> Dear all,
>
> how would I quickly select an element of a Set (as in Data.Set)
> uniformly at random?
If you use a "Map a ()" (or Map a a) you can use Map.elemAt.
The initial conversion is still linear, though.
-- | convert a set into an identity map
setToMap :: Ord a => Set.Set a -> Map.Map a a
setToMap = Map.fromDistinctAscList . List.map (\ a -> (a, a)) . Set.toList
HTH C.
>
> Via the API, this can only be done in linear time? (via toList)
> If I could access the tree structure,
> then of course it could be logarithmic.
>
> But probably I'd need a weighted selection sooner or later,
> and this would require some specific code anyway. Or does it not?
>
> Actually I need a sequence of such selections
> (each selected element is deleted immediately).
> I don't need all elements
> (so, computing a random permuation might be too much).
>
> J.W.
>
More information about the Haskell-Cafe
mailing list