Skip to content

Latest commit

 

History

History
26 lines (18 loc) · 600 Bytes

StableSort.md

File metadata and controls

26 lines (18 loc) · 600 Bytes

structure StableSort

type 'a seq = 'a Seq.t

We use the Seq representation of sequences for these functions.

val sortInPlace: ('a * 'a -> order) -> 'a seq -> unit

sortInPlace cmp s sorts s and writes the result in-place. This is guaranteed to be stable: the relative order of equal elements is preserved. The algorithm used is a merge-sort.

Work: O(|s|log|s|)

Span: polylog|s|

val sort: ('a * 'a -> order) -> 'a seq -> 'a seq

A purely functional version. The input is not modified; instead, a fresh array is produced as output.