Дерево Фенвика — различия между версиями
 (→Запрос изменения элемента)  | 
				|||
| Строка 16: | Строка 16: | ||
== Запрос изменения элемента ==  | == Запрос изменения элемента ==  | ||
| − | Нам надо научиться быстро изменять частичные суммы в зависимости от того, как изменяются элементы. Рассмотрим как изменять величину a_{k} на величину d. Тогда нам надо изменить элементы дерева T_{j}, для которых верно неравенство F(j)   | + | Нам надо научиться быстро изменять частичные суммы в зависимости от того, как изменяются элементы. Рассмотрим как изменять величину <tex>a_{k}</tex> на величину <tex>d</tex>. Тогда нам надо изменить элементы дерева <tex>T_{j}</tex>, для которых верно неравенство <tex>F(j) \le k \le j</tex>. Все <tex>j</tex> мы можем получить следующим образом : <tex>j_{next} = j_{prev} | j_{prev+1} </tex>.  | 
== Запрос получения суммы на префиксе ==  | == Запрос получения суммы на префиксе ==  | ||
Версия 22:48, 8 мая 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: Дерево Фенвика
