У інформатиці, дерево відрізків це деревоподібнаструктура даних яка застосовується для зберігання даних у відрізках, згрупованих так, що відомо, які з них містять дану точку.
Дерево відрізків для множини з відрізків використовує пам'яті і його можна побудувати за часу. Дерево забезпечує виконання операції зі знаходження усіх відрізків, що містять задану точку за час де — кількість отриманих відрізків.[1]
Звернімо увагу, що для відповіді на запит про належність точки інтервалам із використанням дерева інтервалів потрібно так само часу за умови лінійної кількості пам'яті, отже для цього завдання краще обирати дерево інтервалів. Коли ж ми бажаємо отримати відповідь на складніші запитання як-от вікнування відрізків тоді дерево відрізків потужніша структура. Причиною цього є те, що множина інтервалів, що включають запитану точку, є саме об'єднанням канонічних підмножин які ми вибираємо під час пошуку у дереві. У дереві інтервалів ми повинні додатково пройти декілька елементів з початку відсортованих списків, що зберігаються у вузлах дерева. Отже, для дерева відрізків, ми маємо можливість збереження канонічних підмножин у асоціативній структурі, що дає можливість виконання додаткових запитів уже у цій структурі.
Опис структури
Цей розділ описує структуру дерева відрізків в одновимірному просторі.
Нехай S буде набором інтервалів або відрізків. Нехай p1, p2, ..., pm буде списком відмінних кінців інтервалів, відсортованих зліва направо. Розглянемо розбиття дійсної лінії цими точками. Регіони такого розбиття називають елементарними інтервалами. Отже, елементарними інтервалами є, зліва направо:
Це є список елементарних інтервалів між послідовними кінцевими точками pi і pi+1, що перемежаються з закритими інтервалами, що складаються з однієї точки. Одна точка розглядається як інтервал, оскільки відповідь на запит не обов'язково однакова всередині елементарного інтервалу і на його границях.[2]
Для заданої множини інтервалів або відрізків I, дерево відрізківT структуровано так:
Його листові вузли відповідають елементарним інтервалам утвореним в I, впорядкованим способом: найлівіший лист відповідає найлівішому інтервалу і так далі. Елементарний інтервал, що відповідає листу v позначають Int(v).
Внутрішній вузол T відповідає інтервалу який є об'єднанням елементарних інтервалів: інтервал Int(N) відповідний вузлу N є об'єднанням інтервалів відповідних листям дерева з коренем у N. Тобто, Int(N) є об'єднанням інтервалів своїх двох дочірніх вузлів.
Кожен вузол або лист v у T зберігає інтервал Int(v) і множину інтервалів, у деякій структурі даних. Ця канонічна підмножина вузла v містить інтервали [x, x′] з I такі, що [x, x′] містить Int(v) і не містить Int(parent(v)). Тобто, кожен відрізок у I зберігає відрізки, що покривають цей інтервал, але не покривають інтервал батьківського вузла.[3]