Бор
Бор (trie, луч, нагруженное дерево) — структура данных для хранения набора строк, представляющая из себя подвешенное дерево с символами на ребрах. Строки получаются прохождением из корня по рёбрам, записывая соответствующие им символы, до терминальной вершины. Размер бора линейно зависит от суммы длин всех строк, а поиск в бору занимает время, пропорциональное длине образца.
Пример бора
Бор для набора образцов {he, she, his, hers}:
Построение бора
Пусть — набор строк, называемый словарем.
Пусть .
Начинаем с дерева из одной вершины (корня); добавляем шаблоны один за другим: Следуем из корня по ребрам, отмеченным буквами из , пока возможно.
Если заканчивается в , сохраняем идентификатор (например, ) в .
Если ребра, отмеченного очередной буквой нет, то создаем новые ребра и вершины для всех оставшихся символов .
Это занимает, очевидно, времени.
Поиск строки в бору
Поиск строки в бору: начинаем в корне, идем по ребрам, отмеченным символами , пока возможно. Если с последним символом мы приходим в вершину с сохраненным идентификатором, то — слово из словаря. Если в какой-то момент ребра, отмеченного нужным символом, не находится, то строки S в словаре нет. Ясно, что это занимает времени. Таким образом, бор - это эффективный способ хранить словарь и искать в нем слова.