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