昏睡渐醒 2019-10-18 16:30 采纳率: 60%
浏览 936
已采纳

Fibonacci数列求第n项值,当n的数值比较大时,结果会变成负数,请问有没有更好的解决方法?如下,我在求Fibonacci数列求第n项值除以10007的余数,当输入的n为几十,结果就是负数了。

#define N 100000
...

int main()
{
long qiujiecheng(long n);
long n;
scanf_s("%ld", &n);
n = qiujiecheng(n);
printf("%ld", n);
if (n < 10007)
{
printf("%d", n);
}
else {
n %= 10007;
printf("%ld", n);
}
}
long qiujiecheng(long n)
{
static int a[N];
a[1] = a[0] = 1;
for (int i = 2; i < n; i++)
{
a[i] = a[i - 1] + a[i - 2];
}
return a[n - 1];
}

  • 写回答

2条回答 默认 最新

  • Cin.白术 2019-10-18 19:06
    关注

    首先给出一个定理吧:
    (a+b)%d=(a%d+b%d)%d.
    所以如果你把每一次的运算修改成
    a[i] = (a[i - 1] + a[i - 2])%10007;
    就会保证a[i]的数值恒在int范围内,并且可以支持比较大的n运行。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作