View source code
Display the source code in std/range/package.d from which this
page was generated on github.
Report a bug
If you spot a problem with this page, click here to create a
Bugzilla issue.
Improve this page
Quickly fork, edit online, and submit a pull request for this page.
Requires a signed-in GitHub account. This works well for small changes.
If you'd like to make larger changes you may want to consider using
local clone.
Function std.range.SortedRange.trisect
Returns a tuple r
such that r[0]
is the same as the result
of lowerBound(value)
, r[1]
is the same as the result of equalRange(value)
, and r[2]
is the same as the result of upperBound(value)
. The call is faster than computing all three
separately. Uses a search schedule similar to equalRange
. Completes the entire search in Ο(log(n)
) time.
auto auto trisect(V)
(
V value
)
if (isTwoWayCompatible!(predFun, ElementType!Range, V) && isRandomAccessRange!Range && hasLength!Range);
Example
import std .algorithm .comparison : equal;
auto a = [ 1, 2, 3, 3, 3, 4, 4, 5, 6 ];
auto r = assumeSorted(a) .trisect(3);
assert(equal(r[0], [ 1, 2 ]));
assert(equal(r[1], [ 3, 3, 3 ]));
assert(equal(r[2], [ 4, 4, 5, 6 ]));
Authors
Andrei Alexandrescu, David Simcha, Jonathan M Davis, and Jack Stouffer. Credit for some of the ideas in building this module goes to Leonardo Maffi.
License
Copyright © 1999-2018 by the D Language Foundation | Page generated by ddox.