Дерево Фенвика — различия между версиями
| Строка 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: Дерево Фенвика