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