Py小郑 2021-12-27 17:29 采纳率: 96.6%
浏览 82
已结题

有关斐波那契数列Python

要求求斐波那契数列F(n)除以10007所得余数 n是整数

def fabo(x):
    a,b=1,1
    for i in range(2,x):
        a,b=b%10007,(a+b)%10007
    return b
        



def fabo1(x):
    a,b=1,1
    for i in range(2,x):
        a,b=b,(a+b)
    return b

在F(n)<10007这两个结果等价,但是F(n)>10007的时候这两个为什么等价(我运行一下结果一样),我感觉我用数学解释不来,请求指导

  • 写回答

3条回答 默认 最新

  • Hann Yang 全栈领域优质创作者 2021-12-27 18:46
    关注
    def fabo(x):
        a,b=1,1
        for i in range(2,x):
            a,b=b%10007,(a+b)%10007
        return b
            
    def fabo1(x):
        a,b=1,1
        for i in range(2,x):
            a,b=b,(a+b)
        return b
    
    for i in range(1,20000):
        if fabo(i)!=fabo1(i):
            print(i,fabo(i))
            print(i,fabo1(i))
            print(i-1,fabo(i-1))
            print(i-1,fabo1(i-1))
            print(i-2,fabo(i-2))
            print(i-2,fabo1(i-2))
            break
    

    21 939
    21 10946
    20 6765
    20 6765
    19 4181
    19 4181

    6765+4181
    10946
    10946%10007
    939

    x<21时,两函数相等的,
    x=21时 a+b>10007就不相等了

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

报告相同问题?

问题事件

  • 系统已结题 1月4日
  • 已采纳回答 12月27日
  • 修改了问题 12月27日
  • 创建了问题 12月27日

悬赏问题

  • ¥15 关于logstash转发日志时发生的部分内容丢失问题
  • ¥17 pro*C预编译“闪回查询”报错SCN不能识别
  • ¥15 微信会员卡接入微信支付商户号收款
  • ¥15 如何获取烟草零售终端数据
  • ¥15 数学建模招标中位数问题
  • ¥15 phython路径名过长报错 不知道什么问题
  • ¥15 深度学习中模型转换该怎么实现
  • ¥15 Stata外部命令安装问题求帮助!
  • ¥15 从键盘随机输入A-H中的一串字符串,用七段数码管方法进行绘制。提交代码及运行截图。
  • ¥15 如何用python向钉钉机器人发送可以放大的图片?