> 데이터 베이스 > MySQL 튜토리얼 > 一个台阶总共有n 级,如果一次可以跳1 级,也可以跳2 级,求总共

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

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
풀어 주다: 2016-06-07 15:09:49
원래의
2912명이 탐색했습니다.

题目: 一个台阶总共有n 级,如果一次可以跳1 级,也可以跳2 级,求总共有多少总跳法,并分析算法的时间复杂度。 注: 这道题最近经常出现,包括MicroStrategy 等比较重视算法的公司都曾先后选用过个这道题作为面试题或者笔试题。 思路一: 首先我们考虑最简

题目:

一个台阶总共有n 级,如果一次可以跳1 级,也可以跳2 级,求总共有多少总跳法,并分析算法的时间复杂度。

注:
这道题最近经常出现,包括MicroStrategy 等比较重视算法的公司都曾先后选用过个这道题作为面试题或者笔试题。

 

思路一:

首先我们考虑最简单的情况:如果只有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)。
我们把上面的分析用一个公式总结如下:
       /  1  (n=1)
f(n) =  2  (n=2)
       \  f(n-1) + (f-2)  (n>2)
分析到这里,相信很多人都能看出这就是我们熟悉的Fibonacci 序列。(O(n))

 

代码如下:

[cpp] view plaincopyprint?

  1. /*---------------------------- 
  2. Copyright by yuucyf. 2011.08.16 
  3. -----------------------------*/  
  4.   
  5. #include "stdafx.h"  
  6. #include   
  7. using namespace std;  
  8.   
  9.   
  10. int JumpStep(int n)  
  11. {  
  12.     if (n return 0;  
  13.     if (n == 1 || n == 2) return n;  
  14.   
  15.     return (JumpStep(n-1) + JumpStep(n-2));  
  16. }  
  17.   
  18. int _tmain(int argc, _TCHAR* argv[])  
  19. {  
  20.     int nStep = 0;  
  21.     cout "请输入台阶数:";  
  22.     cin >> nStep;  
  23.     cout "台阶数为" ",那么总共有" "种跳法." 
  24.     return 0;  
  25. }  
/*----------------------------
Copyright by yuucyf. 2011.08.16
-----------------------------*/

#include "stdafx.h"
#include <iostream>
using namespace std;


int JumpStep(int n)
{
	if (n > nStep;
	cout 


</iostream>
로그인 후 복사
관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿