首页 > 其他 > 详细

JZ-C-09

时间:2016-05-25 20:38:12      阅读:180      评论:0      收藏:0      [点我收藏+]

剑指offer第九题:斐波那契数列

 1 //============================================================================
 2 // Name        : JZ-C-09.cpp
 3 // Author      : Laughing_Lz
 4 // Version     :
 5 // Copyright   : All Right Reserved
 6 // Description : 斐波那契数列
 7 //============================================================================
 8 
 9 #include <iostream>
10 using namespace std;
11 /**
12  *输入n,返回第n个斐波那契数
13  */
14 double Fibonacci(int n) {
15     double fi;
16     if (n <= 0) {
17         return -1; //错误
18     } else if (n == 1 || n == 2) {
19         fi = 1;
20     } else {
21         fi = Fibonacci(n - 1) + Fibonacci(n - 2);//递归的时间复杂度是n的指数递增,还可能导致栈溢出
22     }
23     return fi;
24 }
25 long long Fibonacci1(int n) {
26     long long previous[] = { 1, 1 };//避免重复计算,利用数组存储第n-1和n-2个数。时间复杂度为0(n)
27     if (n <= 0) {
28         return -1; //错误
29     } else {
30         if (n == 1 || n == 2) {
31             return previous[n-1];
32         }
33         for (int m = 2; m < n; m++) {
34             long long pre = previous[1];
35             previous[1] = previous[0] + previous[1];
36             previous[0] = pre;
37         }
38         return previous[1];
39     }
40 }
41 int main() {
42     long long result = Fibonacci1(50);
43     cout << result << endl;
44     return 0;
45     return 0;
46 }

 

JZ-C-09

原文:http://www.cnblogs.com/Laughing-Lz/p/5528215.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!