Skip to content

Latest commit

 

History

History
25 lines (16 loc) · 706 Bytes

README.md

File metadata and controls

25 lines (16 loc) · 706 Bytes

range-tree

Build status

This library is an extended version of the well-known data structure interval tree.

In a traditional interval tree built from n intervals, one interval among the n that has a non-empty intersection with a query interval can be found in time O(log n). This library supports finding all m intervals with non-empty intersection in time O(log(n) + m).

Usage

require 'range_tree'

ranges = [1..2, 2..3, 3..4, 4..5]

tree = RangeTree.new(ranges)

tree.search(3..4)
# => [2..3, 3..4, 4..5]