Python编程----递归求解兔子的数量

描述

兔子的数量以这样的方式增长:每个月的兔子数量等于它前一个月的兔子数量加它前两个月的兔子数量,即f(n)=f(n-1)+f(n-2)。假设第1个月的兔子有2只,第2个月的兔子有3只,你能使用递归的方法求得第n个月的兔子有多少只吗?

输入描述:

输入正整数n,n<10。

输出描述:

输出第n个月的兔子数量。

示例1

输入:

复制代码
3

复制输出:

复制代码
5

复制说明:

复制代码
第一个月2只+第二个月3只=第三个月5只

具体代码实现:

python 复制代码
def count(n):
    if n==1:
        return 2
    elif n==2:
        return 3
    else:
        return count(n-1)+count(n-2)
i=int(input())
if i<10:
    print(count(i))
else:
    print("error")

知识补充:

什么是递归函数:

递归函数是指在函数的定义中使用函数自身的函数。

递归函数通过将一个问题分解成更小的子问题,并在函数内部不断调用自身来解决这些子问题,直到达到基本情况(终止条件)。

递归函数的特点包括:

  1. 问题分解:将原问题分解为与自身相似但规模更小的子问题。
  2. 自调用:函数在执行过程中会调用自身。
  3. 终止条件:存在一个或多个特定条件,当满足这些条件时,递归停止。

解析:

1.思路:由题目可知第一个月和第二个月的兔子的数量是固定的,而从第三个月开始兔子的数量都是前两个月的兔子的数量的总和,这是一个典型的递归函数的例子,自己调用自己,分别调用自己前两次的结果,让他们相加就得到了这一次的结果。

2.实现:因此我们需要定义一个函数来返回兔子的数量,根据我们的思路我们可以使用if-elif-else的语句来判断是第几个月,如果是第一个月(if n==1:),则直接返回2;如果是第二个月(elif n==2:),则直接返回3;如果是第三个月或者三个月以上(else),则返回前两次函数的值: return count(n-1)+count(n-2)

3.接收值,判断是否小于10,input函数接收用户的值,if判断小于10,则将其传参给函数,否则输出错误提示。

相关推荐
曲幽18 小时前
FastAPI + PostgreSQL 实战:给应用装上“缓存”和“日志”翅膀
redis·python·elasticsearch·postgresql·logging·fastapi·web·es·fastapi-cache
学高数就犯困18 小时前
性能优化:LRU缓存(清晰易懂带图解)
算法
Lupino21 小时前
别再只聊 AI 写代码了:技术负责人要把“变更治理”提到第一优先级
python·docker·容器
CoovallyAIHub21 小时前
CVPR 2026 | MixerCSeg:仅2.05 GFLOPs刷新四大裂缝分割基准!解耦Mamba隐式注意力,CNN+Transformer+Mamba三
深度学习·算法·计算机视觉
CoovallyAIHub21 小时前
YOLO26-Pose 深度解读:端到端架构重新设计,姿态估计凭什么跨代领先?
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
化工厂气体泄漏怎么用AI检测?30张图3D重建气体泄漏场景——美国国家实验室NeRF新研究
深度学习·算法·计算机视觉
Flittly1 天前
【从零手写 ClaudeCode:learn-claude-code 项目实战笔记】(6)Context Compact (上下文压缩)
python·agent
曲幽1 天前
FastAPI + PostgreSQL 实战:从入门到不踩坑,一次讲透
python·sql·postgresql·fastapi·web·postgres·db·asyncpg
颜酱1 天前
图的数据结构:从「多叉树」到存储与遍历
javascript·后端·算法
用户8356290780512 天前
使用 C# 在 Excel 中创建数据透视表
后端·python