python经典百题之求分数前N项和

题目:有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13…求出这个数列的前20项之和。

1. 方法一:普通循环

思路:利用循环计算每一项的值,并累加求和。
优点:实现简单,易于理解。
缺点:计算速度稍慢,当计算量较大时效率低下。
代码实现

def sum_sequence(n):
    a, b = 2, 1
    s = 0
    for i in range(n):
        s += a / b
        a, b = a + b, a
    return s

print(sum_sequence(20))

2. 方法二:递归

思路:利用递归计算每一项的值,并累加求和。
优点:实现简单,易于理解。
缺点:同方法一,当计算量较大时效率低下。
代码实现

def fibonacci(n):
    if n == 1:
        return 2
    if n == 2:
        return 3
    return fibonacci(n-1) + fibonacci(n-2)

def sum_sequence(n):
    s = 0
    for i in range(1, n+1):
        s += fibonacci(i) / fibonacci(i-1)
    return s

print(sum_sequence(20))

3. 方法三:列表推导式

思路:利用列表推导式计算每一项的值,并累加求和。
优点:代码简洁,易于理解,计算速度较快。
缺点:计算量较大时,列表占用的内存空间较大。
代码实现

def sum_sequence(n):
    s = sum([fibonacci(i) / fibonacci(i-1) for i in range(1, n+1)])
    return s

print(sum_sequence(20))

4. 方法四:生成器表达式

思路:利用生成器表达式计算每一项的值,并累加求和。
优点:代码简洁,易于理解,计算速度快,不占用过多内存空间。
缺点:无法同时使用列表中的方法。
代码实现

def sum_sequence(n):
    s = sum(fibonacci(i) / fibonacci(i-1) for i in range(1, n+1))
    return s

print(sum_sequence(20))

5. 方法五:数学公式

思路:利用斐波那契数列的特性,直接计算前n项和。
优点:计算速度最快。
缺点:代码实现较复杂,适用范围有限。
代码实现

import math

def sum_sequence(n):
    sqrt5 = math.sqrt(5)
    s = (pow((1+sqrt5)/2, n+1) - pow((1-sqrt5)/2, n+1)) / sqrt5 - 1
    return s

print(sum_sequence(20))
最推荐的方法是方法四,使用了生成器表达式,代码简洁易懂,计算速度快,内存空间占用较少。
### Python 编程练习分制成绩处理 #### 成绩转换逻辑说明 对于给定的分制成绩,可以将其按照特定区间映射至五级评分体系。具体而言: - 当成绩位于 `0` 到 `59` 分之间时,对应于 E 级; - 对于 `70` 到 `79` 的分数范围,给予 C 级评价并表示恭喜通过测试; - 如果成绩介乎 `80` `89` 之内,那么这会被认为是 B 级的成绩,同样附带祝贺语句; - 而当得分达到或超过 `90` 分以上者,将被评为 A 级,亦会收到相应的鼓励话语[^1]。 #### 实现代码展示 下面是一份完整的 Python 函数用于执行上述描述中的成绩转换操作: ```python def convert_score_to_grade(score_str): pattern = r'^(?:0|100|[1-9]\d?(\.\d+)?)$' match_result = re.match(pattern, score_str) if not match_result: return "输入数据有误!" try: score_num = float(match_result.group()) grade_messages = [ ("E", ""), ("D", "祝贺你通过考试!"), ("C", "祝贺你通过考试!"), ("B", "祝贺你通过考试!"), ("A", "祝贺你通过考试!") ] boundaries = (60, 70, 80, 90) index = sum([score_num >= boundary for boundary in boundaries]) grade, message = grade_messages[index] result_message = f"输入成绩属于{grade}级别。\n{message}" return result_message except ValueError as ve: return str(ve) if __name__ == "__main__": user_input = input("请输入您的成绩:") print(convert_score_to_grade(user_input)) ``` 此段脚本不仅实现了基本的功能需,还加入了正则表达式的验证来确保用户的输入合法有效。此外,在异常捕获部分也做了改进以提高程序健壮性[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

忧伤的玩不起

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值