Дерево Фенвика — различия между версиями
Строка 15: | Строка 15: | ||
В качестве операции <tex> G </tex> рассмотрим операцию сложения. <br/> | В качестве операции <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>. | ||
+ | |||
+ | Приведем код функции <tex> sum(i) </tex> на C++: | ||
+ | <code> | ||
+ | int sum(int i) | ||
+ | { | ||
+ | int result = 0; | ||
+ | while (i >= 0) | ||
+ | { | ||
+ | result += t[i]; | ||
+ | i = f(i) - 1; | ||
+ | } | ||
+ | return result; | ||
+ | } | ||
+ | </code> | ||
== Полезные ссылки: == | == Полезные ссылки: == |
Версия 06:48, 1 мая 2011
Определение: |
Дерево Фе́нвика (Binary indexed tree) - структура данных, требующая
| памяти и позволяющая эффективно (за )
Впервые описано Питером Фенвиком в 1994 году.
Пусть дан массив
Деревом Фенвика будем называть массив из элементов: , где - некоторая функция.
Дерево Фенвика, запрос изменения элемента
Запрос получения суммы на префиксе
В качестве операции
Обозначим . Тогда .
Приведем код функции
на C++:
int sum(int i)
{
int result = 0;
while (i >= 0)
{
result += t[i];
i = f(i) - 1;
}
return result;
}
Полезные ссылки:
Peter M. Fenwick: A new data structure for cumulative frequency
Wikipedia: Fenwick tree
e-maxx.ru: Дерево Фенвика