Дерево Фенвика — различия между версиями
Строка 6: | Строка 6: | ||
}} | }} | ||
Впервые описано Питером Фенвиком в 1994 году. | Впервые описано Питером Фенвиком в 1994 году. | ||
+ | |||
+ | Пусть дан массив <tex> A </tex> из <tex> n </tex> элементов: <tex> a_i, i = \overline{0, n} </tex>.<br/> | ||
+ | Деревом Фенвика будем называть массив <tex> T </tex> из <tex> n </tex> элементов: <tex> T_i = \sum\limits_{k = F(i)}^{i} a_k, i = \overline{0, n} </tex>, где <tex> F(i) </tex> - некоторая функция. | ||
== Дерево Фенвика, запрос изменения элемента == | == Дерево Фенвика, запрос изменения элемента == | ||
== Запрос получения суммы на префиксе == | == Запрос получения суммы на префиксе == | ||
− | + | В качестве операции <tex> G </tex> рассмотрим операцию сложения. <br/> | |
Обозначим <tex> G_i = sum(i) = \sum\limits_{k = 0}^{i} a_k </tex>. Тогда <tex> sum(i, j) = \sum\limits_{k = i}^{j} a_k = G_j - G_{i - 1} </tex>. | Обозначим <tex> G_i = sum(i) = \sum\limits_{k = 0}^{i} a_k </tex>. Тогда <tex> sum(i, j) = \sum\limits_{k = i}^{j} a_k = G_j - G_{i - 1} </tex>. | ||
Версия 06:26, 1 мая 2011
Определение: |
Дерево Фе́нвика (Binary indexed tree) - структура данных, требующая
| памяти и позволяющая эффективно (за )
Впервые описано Питером Фенвиком в 1994 году.
Пусть дан массив
Деревом Фенвика будем называть массив из элементов: , где - некоторая функция.
Дерево Фенвика, запрос изменения элемента
Запрос получения суммы на префиксе
В качестве операции
Обозначим . Тогда .
Полезные ссылки:
Peter M. Fenwick: A new data structure for cumulative frequency
Wikipedia: Fenwick tree
e-maxx.ru: Дерево Фенвика