蓝桥杯 历届试题 斐波那契 Python (快速斐波那契)

资源限制
时间限制:1.0s 内存限制:256.0MB
问题描述
  斐波那契数列大家都非常熟悉。它的定义是:

f(x) = 1 … (x=1,2)
  f(x) = f(x-1) + f(x-2) … (x>2)

对于给定的整数 n 和 m,我们希望求出:
  f(1) + f(2) + … + f(n) 的值。但这个值可能非常大,所以我们把它对 f(m) 取模。
  公式如下
  在这里插入图片描述

但这个数字依然很大,所以需要再对 p 求模。
输入格式
  输入为一行用空格分开的整数 n m p (0 < n, m, p < 10^18)
输出格式
  输出为1个整数,表示答案
样例输入
2 3 5
样例输出
0
样例输入
15 11 29
样例输出
25

分析:
如果按照题目意思傻傻的做,把斐波那契用迭代的方法写,其余的按照公式来,肯定会超时,能通过40%,但是比较划算,40%的代码如下:

while True:
    try:
        n,m,p = map(int,input().split())
        def f(n):
            res1,res2 = 1,1
            for i in range(3,n+1):
                res1,res2 = res2,(res1+res2)
            return res2
        res = 0
        for i in range(1,n+1):
            res+=f(i)
        print(res%f(m)%p)
    except:
        break

下面来编写能过100%的

First

关于斐波那契求和:
Σ f ( i ) = f ( 1 ) + f ( 2 ) + . . . + f ( n ) Σf(i)=f(1)+f(2)+...+f(n) Σf(i)=f(1)+f(2)+...+f(n)
f ( 0 ) = 0 f(0)=0 f(0)=0
f ( 1 ) = f ( 2 ) − f ( 0 ) f(1)=f(2)-f(0) f(1)=f(2)f(0)
f ( 2 ) = f ( 3 ) − f ( 1 ) f(2)=f(3)-f(1) f(2)=f(3)f(1)
f ( 3 ) = f ( 4 ) − f ( 2 ) f(3)=f(4)-f(2) f(3)=f(4)f(2)
f ( 4 ) = f ( 5 ) − f ( 3 ) f(4)=f(5)-f(3) f(4)=f(5)f(3)
f ( 5 ) = f ( 6 ) − f ( 4 ) f(5)=f(6)-f(4) f(5)=f(6)f(4)

f ( n −

  • 14
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值