hdu 2041:超级楼梯(水题,递归)

超级楼梯

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 23642    Accepted Submission(s): 12153

Problem Description
有一楼梯共M级,刚开始时你在第一级,若每次只能跨上一级或二级,要走上第M级,共有多少种走法?
 
Input
输入数据首先包含一个整数N,表示测试实例的个数,然后是N行数据,每行包含一个整数M(1<=M<=40),表示楼梯的级数。

Output
对于每个测试实例,请输出不同走法的数量

Sample Input
2
2
3
 
Sample Output
1
2
 
Author
lcy
 
Source
2005实验班短学期考试
Recommend lcy

 


 

  水题,递归。

  很有意思的一道递归题,用普通的递归会超时,需要改用记忆递归法。记忆递归法,牺牲空间来换取时间,可以采用数组(数组空间浪费大,但是读取速度快)。

code:

 1 Problem : 2041 ( 超级楼梯 )     Judge Status : Accepted
 2 RunId : 8925185    Language : G++    Author : freecode
 3 Code Render Status : Rendered By HDOJ G++ Code Render Version 0.01 Beta
 4 
 5 #include <iostream>
 6 using namespace std;
 7 
 8 /*  用普通递归会超时,改用记忆递归法(将数据存储在数组里)
 9 int m;
10 
11 int f(int n)
12 {
13     if(n>m)
14         return 0;
15     else if(n==m)
16         return 1;
17     else
18         return f(n+1)+f(n+2);
19 }
20 */
21 
22 int main()
23 {
24     /*
25     int T;
26     cin>>T;
27     while(T--){
28         cin>>m;
29         cout<<f(1)<<endl;
30     }
31     */
32 
33     int a[41];
34     a[1]=1,a[2]=1;
35 
36     for(int i=3;i<=40;i++)  //记忆递归法。牺牲空间,换取时间。
37         a[i]=a[i-1]+a[i-2];
38 
39     int T,m;
40     cin>>T;
41     while(T--){
42         cin>>m;
43         cout<<a[m]<<endl;
44     }
45     return 0;
46 }

 

 


 

 

  第二次做。

  水题。

  常规做法会超时,输出几组连续的测试数据会发现,输出结果是斐波那契数列。那么题目就简单了,直接构造一个40以内的斐波那契数列即可,f1=1,f2=1。

  常规做法是写一个递归,作用是记录当前走到了哪一级阶梯(假设为n),所以出口是当n>M(直接return;)或者n==M(sum++;return ;),递归体是f(n+1)然后f(n+2),分别表示当前走1级阶梯和2级阶梯的情况。

  代码:

 

 1 #include <iostream>
 2 
 3 using namespace std;
 4 int sum;
 5 int m;
 6 int a[41];
 7 void f()
 8 {
 9     a[1] = 1;
10     a[2] = 1;
11     for(int i=3;i<=40;i++)
12         a[i] = a[i-1] + a[i-2];
13 }
14 int main()
15 {
16     int n;
17     f();
18     cin>>n;
19     while(n--){
20         cin>>m;
21         cout<<a[m]<<endl;
22     }
23     return 0;
24 }

 

 

Freecode : www.cnblogs.com/yym2013

posted @ 2013-08-13 10:32  Freecode#  阅读(808)  评论(0编辑  收藏  举报