Дерево Фенвика
Версия от 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: Дерево Фенвика

