鱼C论坛

 找回密码
 立即注册
查看: 2745|回复: 4

[已解决]python数列求和

[复制链接]
发表于 2021-6-10 15:59:57 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
数列a1=1,an=an-1/(1+an-1 ^0.5),n和n-1是下标。(好像是个高考题,正好最近在学Python,就想着试试编程做一做)
我想计算每一项的值以及求和,那我这个代码哪里出错了么,funa(30)和suma(30)就出不来结果,而且20往后出结果越来越慢。
def funa(n):
    if n == 1:
        return 1
    else:
        return (funa(n-1) / (1+ funa(n-1)**0.5))  
    
def suma(n):
    sum = 0
    for i in range(1,n):
        sum = sum + funa(i)
    return sum 
最佳答案
2021-6-11 10:43:14
给你加两行代码

另外注意,suma(30)是取不到 30 的,想取到 30 要记得 range(1,n+1)
from functools import lru_cache

@lru_cache()
def funa(n):
    if n == 1:
        return 1
    else:
        return (funa(n-1) / (1+ funa(n-1)**0.5))  
    
def suma(n):
    sum = 0
    for i in range(1,n):
        sum = sum + funa(i)
    return sum 
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-6-11 10:43:14 | 显示全部楼层    本楼为最佳答案   
给你加两行代码

另外注意,suma(30)是取不到 30 的,想取到 30 要记得 range(1,n+1)
from functools import lru_cache

@lru_cache()
def funa(n):
    if n == 1:
        return 1
    else:
        return (funa(n-1) / (1+ funa(n-1)**0.5))  
    
def suma(n):
    sum = 0
    for i in range(1,n):
        sum = sum + funa(i)
    return sum 
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-6-11 15:22:42 | 显示全部楼层
qq1151985918 发表于 2021-6-11 10:43
给你加两行代码

另外注意,suma(30)是取不到 30 的,想取到 30 要记得 range(1,n+1)

感谢大佬指点,刚开始学,前两行代码还没有接触到。想请问一下,我上面的代码是因为效率太低了,所以出不了结果么
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-6-11 16:01:01 | 显示全部楼层
zsc123xyz147 发表于 2021-6-11 15:22
感谢大佬指点,刚开始学,前两行代码还没有接触到。想请问一下,我上面的代码是因为效率太低了,所以出不 ...

这是没办法的事,递归函数效率就是有这样的问题,效率比较低。我加的这两行是装饰器,等你慢慢学习也会接触到,这个装饰器的作用就是加载缓存并读取缓存数据,在递归用法用效果比较明显,更多的不妨自己百度一下吧。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-6-11 17:51:29 | 显示全部楼层
qq1151985918 发表于 2021-6-11 16:01
这是没办法的事,递归函数效率就是有这样的问题,效率比较低。我加的这两行是装饰器,等你慢慢学习也会接 ...

好的,感谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-8 05:28

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表