上楼梯算法

 1         /// <summary>
 2         /// 上楼梯算法(迭代)
 3         /// </summary>
 4         /// <param name="n"></param>
 5         /// <returns></returns>
 6         private static long fib3(int n)
 7         {
 8             long x = 0, y = 0, z = 1;
 9             long w, k;
10 
11             for (int j = 0; j < n; j++)
12             {
13                 w = z;
14                 k = y;
15                 z = x + y + z;
16                 y = w;
17                 x = k;
18             }
19             return z;
20         }
21 
22         /// <summary>
23         /// 上楼梯算法(递归)
24         /// </summary>
25         /// <param name="n"></param>
26         /// <returns></returns>
27         private static long dfib1(int n)
28         {
29             if (n < 1)
30                 return 0; 
31             if (n == 1)
32                 return 1;
33             if (n == 2)
34                 return 2;
35             if (n == 3)
36                 return 4;
37 
38             return dfib1(n - 1) + dfib1(n - 2) + dfib1(n - 3);
39         }

 

posted @ 2012-12-27 17:56  宁静.致远  阅读(625)  评论(0编辑  收藏  举报