Дерево Фенвика — различия между версиями
Строка 20: | Строка 20: | ||
{{Утверждение | {{Утверждение | ||
− | |statement='''Лемма.''' <tex> a_i </tex> входит в сумму для <tex> f_k </tex>, если <tex> \exists j: k = i \vee (1 \cdots 1) j </tex> раз. | + | |statement='''Лемма.''' <tex> a_i </tex> входит в сумму для <tex> f_k </tex>, если <tex> \exists j: k = i \vee \cdots(1 \cdots 1) j </tex> раз. |
− | |proof= | + | |proof=Для доказательства леммы рассмотрим битовую запись следующих чисел: <tex> k - 2^{h(k) + 1} \leq i \leq k </tex> |
+ | * <tex> k - 2^{h(k) + 1} \rightarrow \cdots (0 \cdots 0) </tex> <br/> | ||
+ | * <tex> i \rightarrow \cdots (\cdots) </tex> <br/> | ||
+ | * <tex> k \rightarrow \cdots (1 \cdots 1)</tex> | ||
}} | }} | ||
Приведем код функции <tex> sum(i) </tex> на C++: | Приведем код функции <tex> sum(i) </tex> на C++: |
Версия 18:10, 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: Дерево Фенвика