Skip to content

Instantly share code, notes, and snippets.

@atifaziz
Last active August 29, 2015 13:57
Show Gist options
  • Star 1 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save atifaziz/9838444 to your computer and use it in GitHub Desktop.
Save atifaziz/9838444 to your computer and use it in GitHub Desktop.
GroupAdjacent for sequences in F#
open System.Collections.Generic
let groupAdjacent projection (source : _ seq) = seq {
let rec loop (e : IEnumerator<_>) g (members : List<_>) = seq {
members.Add(e.Current)
if e.MoveNext() then
let key = projection e.Current
if key = g then
yield! loop e key members
else
yield g, seq members
yield! loop e key (List())
else
yield g, seq members
}
use e = source.GetEnumerator()
if e.MoveNext() then
yield! loop e (projection e.Current) (List())
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment