0
フィボナッチをベースにしたキャッシュを実装しようとしています。しかし、それは私に間違った出力を与えました(fibcache(8)は21の代わりに13の答えを与えました)。しかし、場合によっては正しい出力を得ました。例えばfibcache(6)は私に8を与えました。再帰キャッシュベースのフィボナッチ
#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