package grenier
A collection of various algorithms in OCaml
Install
Dune Dependency
Authors
Maintainers
Sources
grenier-v0.8.tbz
sha256=622a34f91f2787096f15786901b8d8cff528cada805b018fdbd522c00c6f13e8
sha512=e687e7c9e7b61d876c70570a9b6e4f3a497c8deb334e28532d8c2f9a2a06bff1330431b64ec3e8c4bcfcf2cc9495723339196608c6c4ac5a0699020d0af93e26
doc/grenier.orderme/Order_interval/index.html
Module Order_interval
Basic ordering operations
val root : unit -> t
Create a new ordering with a single element. O(1)
after t
inserts a new element to the ordering, greater than t
but less than all existing elements greater than t
.
O(1) amortized.
before t
inserts a new element to the ordering, less than t
but greater than all existing elements less than t
.
O(1) amortized.
val cardinal : t -> int
How many elements are ordered. O(1)
Memory management
val forget : t -> unit
When you know you are not going to use an element any longer, forget
it to release memory. It makes operations slightly faster to not have to wait for the GC to release elements.
val is_valid : t -> bool
After calling forget
, an element should not be used. You can check if it is the case with is_valid
.
Algorithm due to: Two Simplified Algorithms for Maintaining Order in a List Bender et al., 2002
val unsafe_check : t -> string -> unit
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>
On This Page