Я пытаюсь реализовать последовательность Фибоначчи на основе кеширования. Но это дало мне неправильный результат, например (fibcache (8) дал мне ответ 13 вместо 21. Однако в некоторых случаях он дал мне правильный результат. Например, фиккач (6) дал мне 8. Не могу понять, что случилосьРекурсивное кэширование на основе Fibonacci
#include <stdio.h>
#include <stdlib.h>
#define DCACHE_SIZE 5
int fibcache(int number);
long cacheodd[DCACHE_SIZE] = {0};
long cacheeven[DCACHE_SIZE] = {0};
int i_odd, i_even;
int main(int argc, char *argv[])
{
int fibNum = fibcache(6);
printf("The Fibonacci number is %d\n", fibcache(fibNum));
}
int fibcache(int n)
{
int result;
if (n == 0)
return 0;
if (n == 1)
return 1;
if(n%2==0)
{
if (cacheodd[i_odd] != 0)
result = cacheodd[i_odd];
else
{
cacheodd[i_odd] = fibcache(n-1) + fibcache(n-2);
result = cacheodd[i_odd];
}
}
else
if(n%2==1)
{
if (cacheeven[i_even] != 0)
result = cacheeven[i_even];
else
{
cacheeven[i_even] = fibcache(n-1) + fibcache(n-2);
result = cacheeven[i_even];
}
}
return result;
}
Вы действительно должны научиться использовать отладчик :) –
новичок в C. Научиться использовать отладчик в моей сделать список, хотя :) –
@xTiraMissU использует утверждения печати :) – Aditya