Мне кажется, что вас попросят вернуть n-й фибоначчи, где n - переданный параметр. Вы можете использовать различные методы для ответа на этот вопрос, тогда как все это зависит от сложности времени и сложности кода.
Метод 1 (использование рекурсии) Простой метод, который представляет собой математическое отношение к выполнению прямой рекультивации, приведенное выше.
int fib(int n)
{
if (n <= 1)
return n;
return fib(n-1) + fib(n-2);
}
Время Сложность: Т (п) = Т (п-1) + Т (п-2), который является экспоненциальной. Мы можем заметить, что эта реализация много повторяет работу (см. Следующее дерево рекурсии). Так что это плохая реализация для n-го числа Фибоначчи.
fib(5)
/ \
fib(4) fib(3)
/ \ / \
fib(3) fib(2) fib(2) fib(1)
/ \ / \ / \
FIB (2) FIB (1) FIB (1) FIB (0) FIB (1) FIB (0) /\ FIB (1) FIB (0) Дополнительное пространство: О (п), если мы рассмотрим размер стека вызовов, в противном случае O (1).
Способ 2 (использование динамического программирования) Мы можем избежать повторной работы, сделанной методом 1, путем хранения вычисляемых чисел Фибоначчи.
int fib(int n)
{
/* Declare an array to store fibonacci numbers. */
int f[n+1];
int i;
/* 0th and 1st number of the series are 0 and 1*/
f[0] = 0;
f[1] = 1;
for (i = 2; i <= n; i++)
{
/* Add the previous 2 numbers in the series
and store it */
f[i] = f[i-1] + f[i-2];
}
return f[n];
}
Время Сложность: О (п) Дополнительное пространство: О (п)
Метод 3 (Космический Otimized Способ 2) Мы можем оптимизировать пространство, используемое в методе 2, сохраняя предыдущие два числа только потому, что это все, что нужно, чтобы получить следующее число Фибаннаси в серии.
int fib(int n)
{
int a = 0, b = 1, c, i;
if(n == 0)
return a;
for (i = 2; i <= n; i++)
{
c = a + b;
a = b;
b = c;
}
return b;
}
Время Сложность: О (п) Дополнительное пространство: O (1)
Метод 4 (использование мощности Matrx {{1,1}, {0,1}}) Это другой O (n), который полагается на то, что если мы n раз умножим матрицу M = {{1,1}, {0,1}} на себя (другими словами вычислим мощность (M, n)), то мы получить (n + 1) -е число Фибоначчи как элемент в строке и столбце (0, 0) в результирующей матрице.
Представление матрицы дает следующее замкнутое выражение для чисел Фибоначчи:
/* Helper function that multiplies 2 matricies F and M of size 2*2, and
puts the multiplication result back to F[][] */
void multiply(int F[2][2], int M[2][2]);
/* Helper function that calculates F[][] raise to the power n and puts the
result in F[][]
Note that this function is desinged only for fib() and won't work as general
power function */
void power(int F[2][2], int n);
int fib(int n)
{
int F[2][2] = {{1,1},{1,0}};
if(n == 0)
return 0;
power(F, n-1);
return F[0][0];
}
void multiply(int F[2][2], int M[2][2])
{
int x = F[0][0]*M[0][0] + F[0][1]*M[1][0];
int y = F[0][0]*M[0][1] + F[0][1]*M[1][1];
int z = F[1][0]*M[0][0] + F[1][1]*M[1][0];
int w = F[1][0]*M[0][1] + F[1][1]*M[1][1];
F[0][0] = x;
F[0][1] = y;
F[1][0] = z;
F[1][1] = w;
}
void power(int F[2][2], int n)
{
int i;
int M[2][2] = {{1,1},{1,0}};
// n - 1 times multiply the matrix to {{1,0},{0,1}}
for (i = 2; i <= n; i++)
multiply(F, M);
}
Время Сложность: O (п) Дополнительное пространство: O (1)
Метод 5 (оптимизированный метод 4) Метод 4 может быть оптимизирован для работы во временной сложности O (Logn). Мы можем сделать рекурсивного умножения, чтобы получить власть (M, N) в prevous методе (по аналогии с оптимизацией, проводимой в этой должности)
void multiply(int F[2][2], int M[2][2]);
void power(int F[2][2], int n);
/* function that returns nth Fibonacci number */
int fib(int n)
{
int F[2][2] = {{1,1},{1,0}};
if(n == 0)
return 0;
power(F, n-1);
return F[0][0];
}
/* Optimized version of power() in method 4 */
void power(int F[2][2], int n)
{
if(n == 0 || n == 1)
return;
int M[2][2] = {{1,1},{1,0}};
power(F, n/2);
multiply(F, F);
if(n%2 != 0)
multiply(F, M);
}
void multiply(int F[2][2], int M[2][2])
{
int x = F[0][0]*M[0][0] + F[0][1]*M[1][0];
int y = F[0][0]*M[0][1] + F[0][1]*M[1][1];
int z = F[1][0]*M[0][0] + F[1][1]*M[1][0];
int w = F[1][0]*M[0][1] + F[1][1]*M[1][1];
F[0][0] = x;
F[0][1] = y;
F[1][0] = z;
F[1][1] = w;
}
Время Сложность: O (LogN) Дополнительное пространство: O (LogN), если мы рассмотрим размер стека вызова функции, иначе O (1).
Программа для водителя: int main() { {img} int n = 9; printf ("% d", fib (9)); getchar(); return 0; }
Ссылки: http://en.wikipedia.org/wiki/Fibonacci_number http://www.ics.uci.edu/~eppstein/161/960109.html
Ах .... это сделало его намного яснее. Спасибо. – KingKongFrog
Вы прочитали мой ответ? –
Предположим, что указан индекс _i_. a) бежать через ряд фидов: 1 1 (он не говорит, как далеко или на что это?) b) return _i_ – greybeard