gpt4 book ai didi

c - 基于斐波那契递归缓存

转载 作者:行者123 更新时间:2023-11-30 16:53:49 24 4
gpt4 key购买 nike

我正在尝试实现基于缓存的斐波那契序列。但它给了我错误的输出,例如(fibcache(8) 给了我 13 而不是 21 的答案。但是在某些情况下,它给了我正确的输出。例如 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;
}

最佳答案

您遇到一些问题:

  • 您实际上打印了 fib(fib(6)),一个比 fib(6) 大得多的数字。

  • 你的缓存函数太复杂了:为什么要以不同的方式处理偶数和奇数?您应该对大于缓存大小的数字进行特殊处理,并验证是否已计算缓存值。

这是一个更简单的版本:

#include <stdio.h>

#define DCACHE_SIZE 5

long fibcache(int number);
long fibcache_values[DCACHE_SIZE] = { 0 };

int main(void) {
printf("List of Fibonacci numbers:\n");
for (int i = 0; i < 47; i++) {
printf(" fib(%d) = %ld\n", fibcache(i));
}
return 0;
}

long fibcache(int n) {
if (n <= 0)
return 0;
if (n == 1)
return 1;
if (n < DCACHE_SIZE) {
if (fibcache_values[n] != 0)
return fibcache_values[n];
else
return fibcache_values[n] = fibcache(n - 1) + fibcache(n - 2);
} else {
return fibcache(n - 1) + fibcache(n - 2);
}
}

关于c - 基于斐波那契递归缓存,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40708026/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com