数学建模社区-数学中国
标题:
Python编程----递归求解兔子的数量
[打印本页]
作者:
2744557306
时间:
2024-4-27 15:41
标题:
Python编程----递归求解兔子的数量
描述
4 z4 y0 J# o/ v
兔子的数量以这样的方式增长:每个月的兔子数量等于它前一个月的兔子数量加它前两个月的兔子数量,即f(n)=f(n-1)+f(n-2)。假设第1个月的兔子有2只,第2个月的兔子有3只,你能使用递归的方法求得第n个月的兔子有多少只吗?
0 t; w3 a/ ?# ?0 p$ ]# @
+ Q, t( k- u- w
输入描述:
3 C( H, }, |# l* v8 e' r( H
输入正整数n,n<10。
1 [. f4 f! v5 f- m& ?, T
5 n r/ V: M6 H; O; E4 v' u
输出描述:
3 d2 {3 k0 S" A3 ^4 Y. O3 ^
输出第n个月的兔子数量。
# i1 [9 E- B& u) S& {
i& X/ ?. J3 g: ]8 s
示例1
( w) m9 ?. H* ]! c, ?. m$ V U: \
输入:
% _8 A* T: h4 ~* u# C3 w* k
) l" ?4 r5 A0 S- Y7 W y
3
5 `% t1 ^( ]7 N$ f( ~( S/ J
复制输出:
Y2 p. p, J, }& {' {
: ]9 c2 s# C( o! y
5
! D; e! A3 r) u( @
复制说明:
& e- U, U. N, A/ y" }
: n4 s1 f1 L5 e* T2 p( \# x- A9 {
第一个月2只+第二个月3只=第三个月5只
: ?" K7 S( q- _- J% m! x7 F, [
具体代码实现:
2 h6 K* J, t$ b/ z( R5 n; Y
def count(n):
- |4 s( W6 N* _4 v* X% {
if n==1:
; r0 D. h- x* e/ F7 U) N" m
return 2
' A0 ~$ B% V7 c( L
elif n==2:
7 `- q8 N, q& ~* N$ `3 w
return 3
: J+ r5 r- x$ W( j7 | o, ]
else:
; _" h9 [4 b8 W4 K
return count(n-1)+count(n-2)
5 ^8 H8 e7 K' o& _8 i( h, W
i=int(input())
. @" P: M$ c4 L- Y
if i<10:
+ N2 T& h) [8 O9 L% `8 L
print(count(i))
, D6 R! ^( r( E( G5 r
else:
8 o. r. Z! Z" Q, c, u1 g4 C* j
print("error")
1 P" @) v8 ^- }+ P
知识补充:
; z1 I% b$ H/ a( m
什么是递归函数:
# z+ w3 h1 u) W* f, L. E
* z, b( Z1 D( O: f8 \9 V
递归函数是指在函数的定义中使用函数自身的函数。
1 U! [2 y! G1 W" s, j) n2 A7 K
6 k; Q9 M# \- ?! M- j- W
递归函数通过将一个问题分解成更小的子问题,并在函数内部不断调用自身来解决这些子问题,直到达到基本情况(终止条件)。
" |$ [/ G2 c5 ~5 Q/ W5 f7 I
0 R! k8 ?* i6 S9 u" O2 X8 y
递归函数的特点包括:
H2 Z7 ]/ X, @& A$ N
, N* Q0 R4 i5 a. O0 l6 ^2 ]! C
问题分解:将原问题分解为与自身相似但规模更小的子问题。
7 Z' X/ ^* K# T" f
自调用:函数在执行过程中会调用自身。
% f) i" _$ ?- J# K6 w: B0 K
终止条件:存在一个或多个特定条件,当满足这些条件时,递归停止。
! m, R* g7 `" y4 G
解析:
3 ?, k& k4 Y- b
1.思路:由题目可知第一个月和第二个月的兔子的数量是固定的,而从第三个月开始兔子的数量都是前两个月的兔子的数量的总和,这是一个典型的递归函数的例子,自己调用自己,分别调用自己前两次的结果,让他们相加就得到了这一次的结果。
O& A: ?! t: X$ T: X- L8 s
/ ]. p$ a# C% c( e
2.实现:因此我们需要定义一个函数来返回兔子的数量,根据我们的思路我们可以使用if-elif-else的语句来判断是第几个月,如果是第一个月(if n==1:),则直接返回2;如果是第二个月(elif n==2:),则直接返回3;如果是第三个月或者三个月以上(else),则返回前两次函数的值: return count(n-1)+count(n-2)
' l+ K% s& R: f8 \: @% f
7 L0 p) k" Z! D, C& k v
3.接收值,判断是否小于10,input函数接收用户的值,if判断小于10,则将其传参给函数,否则输出错误提示。
( {- f2 G6 v# d4 y3 ^0 L
————————————————
% D+ X- g% X& b6 e* s1 _
$ S0 ~4 W5 N. t+ R0 ?# K) ~4 K
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
% T5 t1 P+ y$ s; s+ ~8 L- B
+ b& W' h% R( i* G" t v3 H5 L0 c
原文链接:https://blog.csdn.net/m0_65237356/article/details/138223099
' u! e {4 P3 K( s' y' o
1 ^$ Q5 z3 L, X* T0 q n4 Z4 h2 \
8 ]+ B) H( ~+ _6 L0 Z0 h
欢迎光临 数学建模社区-数学中国 (http://www.madio.net/)
Powered by Discuz! X2.5