QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2551|回复: 0
打印 上一主题 下一主题

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

[复制链接]
字体大小: 正常 放大

1188

主题

4

听众

2931

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-4-27 15:41 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
描述
1 x6 v7 [9 i' B* V, ~3 ~兔子的数量以这样的方式增长:每个月的兔子数量等于它前一个月的兔子数量加它前两个月的兔子数量,即f(n)=f(n-1)+f(n-2)。假设第1个月的兔子有2只,第2个月的兔子有3只,你能使用递归的方法求得第n个月的兔子有多少只吗?% ]' a' G  r' q
, k9 C0 t; w4 V, V" k$ O5 `. n
输入描述:7 f. y! J( Y+ ~9 z" _6 R
输入正整数n,n<10。7 l; S) }1 c+ |3 v
0 s* E# y8 D4 r4 P" @0 ~& _5 M
输出描述:  b3 K! K  s; `$ p
输出第n个月的兔子数量。! F- y/ W  N2 M% H! g
1 H  P2 {1 }9 M; ?9 s
示例1
" g! ~7 t9 Y5 M1 I输入:
' I- [, c9 q( k+ {. M4 Y9 j* @  c3 }
" U9 h* H8 c' ~, V35 A/ q+ p5 x) n$ p
复制输出:
# U" ?! D1 l4 W! I" A* b; o2 v) M/ |' y( e: U( B
5
' O5 q5 ^# O/ O( D复制说明:
  r9 p. C& r1 z  M) E+ B6 u! F1 o( ?4 o. n8 n" o' c
第一个月2只+第二个月3只=第三个月5只
+ |! j$ j8 }& X! d具体代码实现:- G' f8 Q3 ]4 G/ a4 J' Z' o' M
def count(n):
* \1 ?9 R! U! O/ k" @( R6 M* h2 g* y    if n==1:
9 J) [6 N) F) O3 m        return 2
8 r" i5 ?' C, j& `: ~    elif n==2:
0 P% t! i1 ^4 n5 R        return 3
! B& Q  _- S1 |$ a    else:' m9 Q  ]2 [. L/ O
        return count(n-1)+count(n-2)
3 o8 P$ {& l* \( r. ~5 F* C) X) |i=int(input())
. z  y5 N) @* z, F$ H4 E+ D; Fif i<10:
; ]- u" ?3 a+ d$ @+ I9 t0 Y; ^    print(count(i))5 ^7 ~0 F! U; d# o0 M
else:' P2 G3 [$ k# V! M1 @" t" R+ i
    print("error")
) D" @5 |* {! F' T+ M+ o知识补充:+ ?0 H1 T4 d- `
什么是递归函数:$ x3 E: l" ~/ q2 i; z
  E7 R* Q* M: p: Y6 p
递归函数是指在函数的定义中使用函数自身的函数。& K5 d" G& d" H4 ^* q9 Z

; G6 l9 S( Y4 L4 Q4 {递归函数通过将一个问题分解成更小的子问题,并在函数内部不断调用自身来解决这些子问题,直到达到基本情况(终止条件)。. w  Z4 P: X8 }5 ~" p
5 V2 i! K# T& |6 q5 Z
递归函数的特点包括:/ |9 e2 _0 I9 E6 z9 A! n( o3 t) x5 o
: [( g/ A/ p& O& B% L; k, F
问题分解:将原问题分解为与自身相似但规模更小的子问题。6 {  q% Y$ u, b" M% ^, m; u
自调用:函数在执行过程中会调用自身。; K- w5 f" c4 k" }$ P
终止条件:存在一个或多个特定条件,当满足这些条件时,递归停止。
) ^% }& `9 v1 c, p4 Z1 w解析:) Q" L0 B" }( E, L; O' h
1.思路:由题目可知第一个月和第二个月的兔子的数量是固定的,而从第三个月开始兔子的数量都是前两个月的兔子的数量的总和,这是一个典型的递归函数的例子,自己调用自己,分别调用自己前两次的结果,让他们相加就得到了这一次的结果。
0 _0 w/ T" U% N: d! m
+ a$ M5 {- M% M0 w$ G% ?- L! H) n2.实现:因此我们需要定义一个函数来返回兔子的数量,根据我们的思路我们可以使用if-elif-else的语句来判断是第几个月,如果是第一个月(if n==1:),则直接返回2;如果是第二个月(elif n==2:),则直接返回3;如果是第三个月或者三个月以上(else),则返回前两次函数的值: return count(n-1)+count(n-2)2 P6 ~, r; `. F, W% M

% e3 w( L+ Q# B" C5 `' T4 s3.接收值,判断是否小于10,input函数接收用户的值,if判断小于10,则将其传参给函数,否则输出错误提示。
6 [$ P, _* j5 p0 i! R————————————————+ Q" n! H4 `$ o3 j( U, k) x- r

! u1 C8 i; Z' |) Z1 \                            版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。2 A# F. Q+ L8 ?- A7 e, H- @

. D0 F8 C5 i1 L- t5 w, O9 O原文链接:https://blog.csdn.net/m0_65237356/article/details/138223099+ a$ c/ ?& h: f4 h- E1 a
* a+ m( L9 K! Z/ u" M/ I  Y- v

0 T* r1 @; o* P4 p- W
zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

手机版|Archiver| |繁體中文 手机客户端  

蒙公网安备 15010502000194号

Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

GMT+8, 2026-5-26 04:54 , Processed in 0.311777 second(s), 50 queries .

回顶部