Быстрое вычисление членов линейной рекуррентной последовательности
Пусть нам дана линейная реккурента размера . А именно: , а так же заданы первых членов. Требуется уметь вычислять произвольное .
Самый простой способ сделать это — последовательно считать каждый , пока не сравняется с . Однако этот способ не самый эффективный, ведь он, очевидно, требует времени. Хочется уметь как-то быстрее решать эту задачу. Рассмотрим два способа это сделать.
Первый способ (за )
Заметим, что линейные рекурренты хорошо выражаются через матрицы. Запишем наши первые членов последовательности в столбик. Так же выпишем следующую матрицу перехода:
Заметим, что умножив слева на , мы получим столбик следующего вида: Аналогично, домножив слева на , получим
Продолжая так для любого , мы получим столбик , состоящий из подряд идущий членов последовательности, начиная с . Пользуясь ассоциативность произведения матриц, можно записать, что . Из этого соотношения вытекает алгоритм вычисления произвольного :
- Инициализировать матрицы и
- Возвести матрицу в степень
- Посчитать как и взять из него
Используя быстрое возведения в степень второй пункт будет тратить времени, умножение же в третьем пункте выполняется за . Итого мы получили алгоритм за .