一个台阶总共有n级,如果一次可以跳1级,也可以跳2级。求总共有 多少总跳法

阅读: 评论:0

一个台阶总共有n级,如果一次可以跳1级,也可以跳2级。求总共有 多少总跳法

一个台阶总共有n级,如果一次可以跳1级,也可以跳2级。求总共有 多少总跳法

首先我们考虑最简单的情况:如果只有1 级台阶,那显然只有一种跳法,如果有2 级台阶,那就有两种跳的方法了:一种是分两次跳,每次跳1 级;另外一种就是一次跳2 级。
现在我们再来讨论一般情况:我们把n 级台阶时的跳法看成是n 的函数,记为f(n)。当n>2 时,第一次跳的时候就有两种不同的选择:一是第一次只跳1 级,此时跳法数目等于后面剩下的n-1 级台阶的跳法数目,即为f(n-1);另外一种选择是第一次跳2 级,此时跳法数目等于后面剩下的n-2 级台阶的跳法数目,即为f(n-2)。
因此n 级台阶时的不同跳法的总数f(n) = f(n-1) + f(n-2)。
我们把上面的分析用一个公式总结如下:
f(n) =  1  (n=1)
f(n) =  2  (n=2)
f(n) =f(n-1) + (f-2)  (n>2)
分析到这里,相信很多人都能看出这就是我们熟悉的Fibonacci 序列。(O(n))
#include int JumpStep(int n)  
{  if (n <= 0)  return 0;  if (n == 1 || n == 2) return n;  return (JumpStep(n-1) + JumpStep(n-2));  
}  int main(int argc, char *argv[])  
{  int nStep = 0;  printf("请输入台阶数:");  scanf("%d", &nStep);  printf("台阶数为 %d,那么总共有 %d种跳法n", nStep, JumpStep(nStep));  return 0;  
} 

本文发布于:2024-01-29 00:57:13,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170646103611557.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:总共有   台阶   总跳法
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23