Рандомизированное бинарное дерево поиска — различия между версиями
Lex4051 (обсуждение | вклад) м (→Вставка) |
|||
Строка 1: | Строка 1: | ||
− | Рандомизированное бинарное дерево поиска (англ. ''Randomized binary search tree'' | + | '''Рандомизированное бинарное дерево поиска''' (англ. ''Randomized binary search tree, RBST'') {{---}} структура данных, реализующая бинарное дерево поиска. |
==Основная идея и связанные определения== | ==Основная идея и связанные определения== | ||
Строка 11: | Строка 11: | ||
<tex>P[size(L) = i] = \frac{1}n, i = 1..n</tex>. | <tex>P[size(L) = i] = \frac{1}n, i = 1..n</tex>. | ||
}} | }} | ||
− | Из определения следует, что каждый ключ в RBST размера n может оказаться корнем с вероятностью 1/ | + | Из определения следует, что каждый ключ в RBST размера n может оказаться корнем с вероятностью <tex>\frac{1}{n}</tex>. |
Идея RBST состоит в том, что хранимое дерево постоянно является рандомизированным бинарным деревом поиска. Далее подробно будет описана реализация операций над RBST, которая позволит добиться этой цели. Заметим лишь, что хранение RBST в памяти ничем не отличается от хранения обычного дерева поиска: хранится указатель на корень; в каждой вершине хранятся указатели на её сыновей. | Идея RBST состоит в том, что хранимое дерево постоянно является рандомизированным бинарным деревом поиска. Далее подробно будет описана реализация операций над RBST, которая позволит добиться этой цели. Заметим лишь, что хранение RBST в памяти ничем не отличается от хранения обычного дерева поиска: хранится указатель на корень; в каждой вершине хранятся указатели на её сыновей. | ||
Строка 23: | Строка 23: | ||
===Вставка=== | ===Вставка=== | ||
− | Рассмотрим рекурсивный алгоритм вставки ключа <tex>x</tex> в RBST, состоящее из <tex>n</tex> вершин. С вероятностью <tex dpi = "150">\frac{1}{n+1}</tex> вставим ключ в корень дерева, используя процедуру | + | Рассмотрим рекурсивный алгоритм вставки ключа <tex>x</tex> в RBST, состоящее из <tex>n</tex> вершин. С вероятностью <tex dpi = "150">\frac{1}{n+1}</tex> вставим ключ в корень дерева, используя процедуру <tex>\mathrm{insert\_at\_root}</tex>. С вероятностью <tex dpi = "150">1 - \frac{1}{n+1} = \frac{n}{n+1}</tex> вставим его в правое поддерево, если он больше корня, или в левое поддерево, если меньше. Ниже приведён псевдокод процедуры вставки <tex>\mathrm{insert}</tex>, процедуры <tex>\mathrm{insert\_at\_root}</tex>, а также процедуры <tex>\mathrm{split(k)}</tex>, разбивающей дерево на два поддерева, в одном из которых все ключи строго меньше <tex>k</tex>, а в другом больше, либо равны; приведена достаточно очевидная рекурсивная реализация. (через Node обозначен тип вершины дерева, дерево представляется как указатель на корень) |
− | '''Node | + | '''Node''' insert(T, x) |
− | '''int''' r = '''random'''(0..size(T)) | + | '''int''' r = '''random'''(0 .. size(T)) |
− | '''if''' | + | '''if''' r == n |
T = insert_at_root(T, x) | T = insert_at_root(T, x) | ||
− | '''if''' | + | '''if''' x < root.key |
T = insert(T.left, x) | T = insert(T.left, x) | ||
'''else''' | '''else''' | ||
Строка 35: | Строка 35: | ||
'''return''' T | '''return''' T | ||
− | Заметим, что если дерево пусто, то | + | Заметим, что если дерево пусто, то <tex>\mathrm{insert}</tex> с вероятностью 1 делает <tex>x</tex> корнем. |
− | + | '''Node''' insert_at_root(T, x) <font color="green">// вставляем в дерево T ключ x</font> | |
− | '''Node | + | L = RBST() <font color="green">// создать пустые L и R</font> |
− | // создать пустые L и R | ||
− | |||
R = RBST() | R = RBST() | ||
split(T, x, L, R) | split(T, x, L, R) | ||
− | // создать пустое T | + | T = RBST() <font color="green">// создать пустое T</font> |
− | |||
T.key = x | T.key = x | ||
T.left = L | T.left = L | ||
Строка 50: | Строка 47: | ||
'''return''' T | '''return''' T | ||
− | // разделяет дерево T по x | + | split(T, x, L, R) <font color="green"> // разделяет дерево T по x, результат - деревья L и R</font> |
− | + | '''if''' size(T) == 0 | |
− | |||
− | '''if''' | ||
− | |||
L = RBST() | L = RBST() | ||
R = RBST() | R = RBST() | ||
− | '''else | + | '''else if''' x < T.key |
R = T | R = T | ||
split (T.left, x, L, R.left) | split (T.left, x, L, R.left) | ||
Строка 67: | Строка 61: | ||
{{Лемма | {{Лемма | ||
− | |statement= Пусть после операции | + | |statement= Пусть после операции <tex>\mathrm{split}</tex> от дерева <tex>T</tex> по ключу <tex>x</tex> были получены деревья <tex>T_{L}</tex> и <tex>T_{R}</tex>. Тогда если <tex>T</tex> было рандомизированным бинарным деревом поиска, содержащим множество ключей <tex>K</tex>, то деревья <tex>T_{L}</tex> и <tex>T_{R}</tex> {{---}} рандомизированные бинарные деревья поиска, содержащие соответственно множества ключей <tex>K_{L} = \{y \in K | y < x\}</tex> и <tex>K_{R} = \{y \in K | y > x\}</tex>. |
|proof= | |proof= | ||
Применим индукцию по <tex>n</tex> {{---}} размеру дерева. Если <tex>n = 0</tex>, то лемма верна (получим два пустых дерева). | Применим индукцию по <tex>n</tex> {{---}} размеру дерева. Если <tex>n = 0</tex>, то лемма верна (получим два пустых дерева). | ||
− | Пусть <tex>n > 0</tex>, и лемма верна при всех меньших размерах дерева.. Пусть также <tex>y = T.key, L = T.left, R = T.right</tex>. Если <tex>x > y</tex>, то <tex>y</tex> {{---}} корень <tex>T_{L}</tex>, <tex>L</tex> {{---}} левое поддерево <tex>T_{L}</tex>, а | + | Пусть <tex>n > 0</tex>, и лемма верна при всех меньших размерах дерева.. Пусть также <tex>y = T.key, L = T.left, R = T.right</tex>. Если <tex>x > y</tex>, то <tex>y</tex> {{---}} корень <tex>T_{L}</tex>, <tex>L</tex> {{---}} левое поддерево <tex>T_{L}</tex>, а <tex>\mathrm{split}</tex> рекурсивно вызовется от <tex>R</tex>, разделив его на <tex>R'</tex> {{---}} правое поддерево <tex>T_{L}</tex> {{---}}, и <tex>T_{R}</tex>, которые по предположению индукции будут рандомизированными бинарными деревьями поиска. Но <tex>L</tex> также является RBST, т.к. является поддеревом <tex>T</tex>. |
Итак для того, чтобы доказать, что <tex>T_{L}</tex> {{---}} рандомизированное бинарное дерево поиска, осталось показать, что любая его вершина <tex>z</tex> с вероятностью <tex dpi = "150">\frac{1}{m}</tex> окажется в корне, где <tex>m</tex> {{---}} размер <tex>T_{L}</tex>. Действительно: | Итак для того, чтобы доказать, что <tex>T_{L}</tex> {{---}} рандомизированное бинарное дерево поиска, осталось показать, что любая его вершина <tex>z</tex> с вероятностью <tex dpi = "150">\frac{1}{m}</tex> окажется в корне, где <tex>m</tex> {{---}} размер <tex>T_{L}</tex>. Действительно: | ||
Строка 83: | Строка 77: | ||
{{Теорема | {{Теорема | ||
− | |statement= Если <tex>T</tex> {{---}} рандомизированное бинарное дерево поиска, содержащее множество ключей <tex>K</tex>, <tex>x \notin K</tex>, тогда процедура | + | |statement= Если <tex>T</tex> {{---}} рандомизированное бинарное дерево поиска, содержащее множество ключей <tex>K</tex>, <tex>x \notin K</tex>, тогда процедура <tex>\mathrm{insert(x, T)}</tex> вернёт рандомизированное бинарное дерево поиска <tex>T</tex>, содержащее множество ключей <tex>K \cap x</tex>. |
|proof= | |proof= | ||
− | Применим индукцию по <tex>n</tex> {{---}} размеру дерева. Если <tex>n = 0</tex>, то теорема верна: после операции | + | Применим индукцию по <tex>n</tex> {{---}} размеру дерева. Если <tex>n = 0</tex>, то теорема верна: после операции <tex>\mathrm{insert(x, T)}</tex> получим дерево с корнем <tex>x</tex> и двумя пустыми поддеревьями. |
Пусть <tex>n > 0</tex>, и теорема верна при всех меньших размерах дерева. Возможны два случая: <tex>x</tex> вставляется в корень или рекурсивно в одно из поддеревьев. | Пусть <tex>n > 0</tex>, и теорема верна при всех меньших размерах дерева. Возможны два случая: <tex>x</tex> вставляется в корень или рекурсивно в одно из поддеревьев. | ||
Строка 98: | Строка 92: | ||
===Удаление=== | ===Удаление=== | ||
− | Алгоритм удаления использует операцию | + | Алгоритм удаления использует операцию <tex>\mathrm{merge}</tex> {{---}} слияние двух деревьев, удовлетворяющих условию: все ключи в одном из деревьев меньше ключей во втором. Для того, чтобы удалить некоторый ключ <tex>x</tex> из RBST сначала найдём вершину с этим ключом в дереве, используя стандартный алгоритм поиска. Если вершина не найдена, то выходим из алгоритма; в противном случае сливаем правое и левое поддеревья <tex>x</tex> (заметим, что ключи в левом поддереве меньше ключей в правом), удаляем <tex>x</tex>, а корень образовавшегося дерева делаем новым сыном родителя <tex>x</tex>. Псевдокод процедур удаления и слияния приведён ниже. |
− | + | '''Node''' remove(T, x) <font color="green">// удаляет ключ x из дерева T</font> | |
− | '''Node | + | '''if''' size(T) == 0 |
− | '''if''' | ||
− | |||
T = RBST() | T = RBST() | ||
− | '''return''' T | + | '''return''' T <font color="green">// вернуть пустое поддерево</font> |
− | '''if''' | + | '''if''' x < T.key |
T.left = remove(T.left, x) | T.left = remove(T.left, x) | ||
− | '''else | + | '''else if''' x > T.key |
T.right = remove(T.right, x) | T.right = remove(T.right, x) | ||
'''else''' | '''else''' | ||
− | |||
Q = RBST() | Q = RBST() | ||
Q = merge(T.left, T.right) | Q = merge(T.left, T.right) | ||
Строка 117: | Строка 108: | ||
'''return''' T | '''return''' T | ||
− | + | '''Node''' merge(L, R) <font color="green">// сливает деревья L и R, результат - дерево T</font> | |
− | |||
− | '''Node | ||
'''int''' m = L.size | '''int''' m = L.size | ||
'''int''' n = R.size | '''int''' n = R.size | ||
'''int''' total = m + n | '''int''' total = m + n | ||
− | '''if''' | + | '''if''' total == 0 |
− | |||
T = RBST() | T = RBST() | ||
− | '''return''' T | + | '''return''' T <font color="green">// вернуть пустое поддерево</font> |
− | '''int''' r = random(1..total) | + | '''int''' r = random(1 .. total) |
− | '''if''' | + | '''if''' r < m |
− | + | L.right = merge(L.right, R) <font color="green">// с вероятностью m / (m + n)</font> | |
− | L.right = merge(L.right, R) | ||
'''return''' L | '''return''' L | ||
− | '''if''' | + | '''if''' r < m |
− | + | R.left = merge(L, R.left) <font color="green">// с вероятностью m / (m + n)</font> | |
− | R.left = merge(L, R.left) | ||
'''return''' R | '''return''' R | ||
Строка 140: | Строка 126: | ||
{{Лемма | {{Лемма | ||
− | |statement= Пусть <tex>L</tex> и <tex>R</tex> {{---}} рандомизированные бинарные деревья поиска, содержащие соответственно множества ключей <tex>K_{L}</tex> и <tex>K_{R}</tex>, причём <tex>K_{L} < K_{R}</tex> (то есть каждый элемент <tex>K_{L}</tex> меньше каждого элемента <tex>K_{R}</tex>). Тогда операция | + | |statement= Пусть <tex>L</tex> и <tex>R</tex> {{---}} рандомизированные бинарные деревья поиска, содержащие соответственно множества ключей <tex>K_{L}</tex> и <tex>K_{R}</tex>, причём <tex>K_{L} < K_{R}</tex> (то есть каждый элемент <tex>K_{L}</tex> меньше каждого элемента <tex>K_{R}</tex>). Тогда операция <tex>\mathrm{merge(L, R)}</tex> вернёт рандомизированное бинарное дерево поиска, содержащее множество ключей <tex>K</tex> = <tex>K_{L} \cap K_{R}</tex>. |
|proof= | |proof= | ||
Пусть <tex>m</tex> и <tex>n</tex> {{---}} размеры <tex>L</tex> и <tex>R</tex> соответственно. Применим индукцию по <tex>m</tex> и <tex>n</tex>. Если <tex>m = 0</tex> или <tex>n = 0</tex>, то лемма верна. | Пусть <tex>m</tex> и <tex>n</tex> {{---}} размеры <tex>L</tex> и <tex>R</tex> соответственно. Применим индукцию по <tex>m</tex> и <tex>n</tex>. Если <tex>m = 0</tex> или <tex>n = 0</tex>, то лемма верна. | ||
Строка 148: | Строка 134: | ||
{{Теорема | {{Теорема | ||
− | |statement= Если <tex>T</tex> {{---}} рандомизированное бинарное дерево поиска, содержащее множество ключей <tex>K</tex>, тогда процедура | + | |statement= Если <tex>T</tex> {{---}} рандомизированное бинарное дерево поиска, содержащее множество ключей <tex>K</tex>, тогда процедура <tex>\mathrm{remove(x, T)}</tex> вернёт рандомизированное бинарное дерево поиска <tex>T'</tex>, содержащее множество ключей <tex>K \backslash \{x\}</tex> |
|proof= | |proof= | ||
Если удаляемый элемент отсутствует в дереве, то теорема верна. | Если удаляемый элемент отсутствует в дереве, то теорема верна. | ||
Строка 160: | Строка 146: | ||
событие <tex>A</tex> {{---}} <tex>y</tex> является коренем <tex>T'</tex>; | событие <tex>A</tex> {{---}} <tex>y</tex> является коренем <tex>T'</tex>; | ||
− | событие <tex>B</tex> {{---}} <tex>x</tex> был корнем <tex>T</tex> (до операции | + | событие <tex>B</tex> {{---}} <tex>x</tex> был корнем <tex>T</tex> (до операции <tex>\mathrm{remove}</tex>); |
− | событие <tex>C</tex> {{---}} <tex>y</tex> стал корнем <tex>T'</tex> после операции | + | событие <tex>C</tex> {{---}} <tex>y</tex> стал корнем <tex>T'</tex> после операции <tex>\mathrm{merge}</tex> (но до этого им не являлся); |
− | событие <tex>D</tex> {{---}} <tex>y</tex> был корнем <tex>T</tex> (до операции | + | событие <tex>D</tex> {{---}} <tex>y</tex> был корнем <tex>T</tex> (до операции <tex>\mathrm{remove}</tex>); |
Тогда: | Тогда: | ||
− | <tex>P[A] = P[A|B] \ | + | <tex>P[A] = P[A|B] \cdot P[B] + P[A|\neg B] \cdot P[\neg B] = P[C] \cdot 1/n + P[D|\neg B] \cdot (n - 1)/n = </tex> |
− | <tex dpi = "150">\frac{1}{n - 1} \ | + | <tex dpi = "150">\frac{1}{n - 1} \cdot \frac{1}{n} + \frac{1}{n - 1} \cdot \frac{n - 1}{n} = \frac{1}{n - 1}</tex>. |
}} | }} | ||
Строка 182: | Строка 168: | ||
==Ссылки== | ==Ссылки== | ||
− | *[http://en.wikipedia.org/wiki/Treap | + | * [http://en.wikipedia.org/wiki/Treap Wikipedia {{---}} Treap] |
− | *[http://en.wikipedia.org/wiki/Random_binary_tree | + | * [http://en.wikipedia.org/wiki/Random_binary_tree Wikipedia {{---}} Random binary tree] |
== Литература == | == Литература == |
Версия 18:59, 24 мая 2015
Рандомизированное бинарное дерево поиска (англ. Randomized binary search tree, RBST) — структура данных, реализующая бинарное дерево поиска.
Содержание
Основная идея и связанные определения
Как известно, можно подобрать такую последовательность операций с бинарным деревом поиска в наивной реализации, что его глубина будет пропорциональна количеству ключей, а следовательно запрос будет выполняться за . Поэтому, если поддерживать инвариант "случайности" в дереве, то можно добиться того, что математическое ожидание глубины дерева будет небольшим. Дадим рекурсивное определение рандомизированного бинарного дерева поиска (RBST).
Определение: |
Пусть
| — бинарное дерево поиска. Тогда
Из определения следует, что каждый ключ в RBST размера n может оказаться корнем с вероятностью
.Идея RBST состоит в том, что хранимое дерево постоянно является рандомизированным бинарным деревом поиска. Далее подробно будет описана реализация операций над RBST, которая позволит добиться этой цели. Заметим лишь, что хранение RBST в памяти ничем не отличается от хранения обычного дерева поиска: хранится указатель на корень; в каждой вершине хранятся указатели на её сыновей.
(Похожие идеи используются в декартовом дереве, поэтому во многих русскоязычных ресурсах термин рандомизированное бинарное дерево поиска используется как синонимическое название декартового дерева и декартового дерева по неявному ключу)
Операции
Операции обхода дерева, поиска ключа, поиска максимума/минимума, поиск следующего/предыдущего элемента выполняются как в обычном дереве поиска, т.к. не меняют структуру дерева.
Вставка
Рассмотрим рекурсивный алгоритм вставки ключа
в RBST, состоящее из вершин. С вероятностью вставим ключ в корень дерева, используя процедуру . С вероятностью вставим его в правое поддерево, если он больше корня, или в левое поддерево, если меньше. Ниже приведён псевдокод процедуры вставки , процедуры , а также процедуры , разбивающей дерево на два поддерева, в одном из которых все ключи строго меньше , а в другом больше, либо равны; приведена достаточно очевидная рекурсивная реализация. (через Node обозначен тип вершины дерева, дерево представляется как указатель на корень)Node insert(T, x) int r = random(0 .. size(T)) if r == n T = insert_at_root(T, x) if x < root.key T = insert(T.left, x) else T = insert(T.right, x) return T
Заметим, что если дерево пусто, то
с вероятностью 1 делает корнем.Node insert_at_root(T, x) // вставляем в дерево T ключ x L = RBST() // создать пустые L и R R = RBST() split(T, x, L, R) T = RBST() // создать пустое T T.key = x T.left = L T.left = R return T
split(T, x, L, R) // разделяет дерево T по x, результат - деревья L и R if size(T) == 0 L = RBST() R = RBST() else if x < T.key R = T split (T.left, x, L, R.left) else L = T split (T.right, x, L.right, R)
Далее рассмотрим как меняется свойство дерева быть рандомизированным при вставке в него ключей.
Лемма: |
Пусть после операции от дерева по ключу были получены деревья и . Тогда если было рандомизированным бинарным деревом поиска, содержащим множество ключей , то деревья и — рандомизированные бинарные деревья поиска, содержащие соответственно множества ключей и . |
Доказательство: |
Применим индукцию по — размеру дерева. Если , то лемма верна (получим два пустых дерева).Пусть , и лемма верна при всех меньших размерах дерева.. Пусть также . Если , то — корень , — левое поддерево , а рекурсивно вызовется от , разделив его на — правое поддерево —, и , которые по предположению индукции будут рандомизированными бинарными деревьями поиска. Но также является RBST, т.к. является поддеревом .Итак для того, чтобы доказать, что — рандомизированное бинарное дерево поиска, осталось показать, что любая его вершина с вероятностью окажется в корне, где — размер . Действительно:(пусть событие — является коренем )Случай, когда симметричен рассмотренному. |
Теорема: |
Если — рандомизированное бинарное дерево поиска, содержащее множество ключей , , тогда процедура вернёт рандомизированное бинарное дерево поиска , содержащее множество ключей . |
Доказательство: |
Применим индукцию по — размеру дерева. Если , то теорема верна: после операции получим дерево с корнем и двумя пустыми поддеревьями.Пусть , и теорема верна при всех меньших размерах дерева. Возможны два случая: вставляется в корень или рекурсивно в одно из поддеревьев.В первом случае правое и левое поддеревья Во втором случае корень у дерева останется прежнем. Заметим, что для каждого по лемме являются рандомизированными BST, а также вероятность того, что окажется в корне, равна . Т.е. новое дерево — рандомизированное BST. вероятность быть корнем была , а корнем он останется с вероятностью , тогда для каждого вероятность быть корнем равна . По предположению же индукции поддерево, в которое вставляется становится рандомизированным бинарным деревом поиска; а т.к. другое поддерево корня было рандомизированным, то новое дерево — рандомизированное BST. |
Пусть
— множество ключей, — какая-то фиксированная перестановка элементов . Из приведённой выше теоремы следует, что если в изначально пустое дерево добавлять ключи P по порядку, то получим дерево , являющееся RBST.Удаление
Алгоритм удаления использует операцию
— слияние двух деревьев, удовлетворяющих условию: все ключи в одном из деревьев меньше ключей во втором. Для того, чтобы удалить некоторый ключ из RBST сначала найдём вершину с этим ключом в дереве, используя стандартный алгоритм поиска. Если вершина не найдена, то выходим из алгоритма; в противном случае сливаем правое и левое поддеревья (заметим, что ключи в левом поддереве меньше ключей в правом), удаляем , а корень образовавшегося дерева делаем новым сыном родителя . Псевдокод процедур удаления и слияния приведён ниже.Node remove(T, x) // удаляет ключ x из дерева T if size(T) == 0 T = RBST() return T // вернуть пустое поддерево if x < T.key T.left = remove(T.left, x) else if x > T.key T.right = remove(T.right, x) else Q = RBST() Q = merge(T.left, T.right) T = Q return T
Node merge(L, R) // сливает деревья L и R, результат - дерево T int m = L.size int n = R.size int total = m + n if total == 0 T = RBST() return T // вернуть пустое поддерево int r = random(1 .. total) if r < m L.right = merge(L.right, R) // с вероятностью m / (m + n) return L if r < m R.left = merge(L, R.left) // с вероятностью m / (m + n) return R
Докажем, что данный алгоритм оставляет рандомизированное дерево рандомизированным.
Лемма: |
Пусть и — рандомизированные бинарные деревья поиска, содержащие соответственно множества ключей и , причём (то есть каждый элемент меньше каждого элемента ). Тогда операция вернёт рандомизированное бинарное дерево поиска, содержащее множество ключей = . |
Доказательство: |
Пусть Пусть и — размеры и соответственно. Применим индукцию по и . Если или , то лемма верна. и , пусть также или . Без потери общности делаем корнем . После рекурсивного слияния правого поддерева и получим рандомизированное бинарное дерево поиска (которое является правым поддеревом нового дерева). Левое же поддерево нового дерева тоже рандомизированное. Также верно, что для любого вероятность быть корнем равна : действительно, вероятность оказаться в корне в до слияния равна , вероятность того, что элемент останется корнем после слияния равна ; осталось применить правило умножения. |
Теорема: |
Если — рандомизированное бинарное дерево поиска, содержащее множество ключей , тогда процедура вернёт рандомизированное бинарное дерево поиска , содержащее множество ключей |
Доказательство: |
Если удаляемый элемент отсутствует в дереве, то теорема верна. Пусть (дерево не пусто), — размер . Докажем теорему по индукции по . Для теорема очевидным образом верна. Пусть , и предположим, что теорема верна для всех деревьев размера меньше .Возможно два случая: если — корень , то по лемме, после удаления получим рандомизированное бинарное дерево поиска; если же — не корень , то рекурсивно удаляется из поддерева исходного дерева, и по предположению индукции после удаления получаем рандомизированное BST. Осталось лишь показать, что для любого вероятность оказаться корнем после удаления равна .Введём обозначения: событие — является коренем ;событие — был корнем (до операции );событие — стал корнем после операции (но до этого им не являлся);событие — был корнем (до операции );Тогда: . |
Анализ времени работы
Очевидно, что время работы приведённых алгоритмов пропорционально глубине дерева. Но т.к. математическое ожидание глубины рандомизированного бинарного дерева поиска есть
, где — число вершин в дереве, то математическое ожидание времени работы поиска, вставки и удаления — также .См. также
Ссылки
Литература
- Martinez, Conrado; Roura, Salvador (1997), "Randomized binary search trees", Journal of the ACM 45
- Seidel, Raimund; Aragon, Cecilia R. «Randomized Search Trees», 1996 г.
- Randomized binary search trees. Lecture notes from a course by Jeff Erickson at UIUC.