码迷,mamicode.com
首页 > 编程语言 > 详细

经典算法详解(1)斐波那契数列的n项

时间:2018-06-18 18:26:57      阅读:186      评论:0      收藏:0      [点我收藏+]

标签:The   详解   整数   iostream   空间   系统   nbsp   argv   stream   

斐波那契数列是一个常识性的知识,它指的是这样的一个数列,它的第一项是1,第二项是1,后面每一项都是它前面两项的和,如:1,1,2,3,5,8,13,21,34,55,89,144,233……

说明:由于通过递推方式效率低,系统开销大,空间复杂度高,故不考虑。

 1 /*斐波那契数列:第一项和第二项为1,后面各项是其前面两项之和*/
 2 /*编写一个函数,输入整数n,求该项的值*/
 3 
 4 #include<iostream>
 5 
 6 using namespace std;
 7 
 8 int fibonacci(int n) {
 9     if (n < 0){
10         return -1;
11     }
12     if ((n == 1 )||( n ==2)) {
13         return 1;
14     }
15     else {
16         int fib_1 = 1,fib_2=1,fib_3;
17         for (int i = 3; i <= n; i++) {
18             fib_3 = fib_1 + fib_2;
19             fib_1 = fib_2;
20             fib_2 = fib_3;
21         }
22         return fib_3;
23     }
24 }
25 
26 int main(int argc, char *argv[]) {
27     cout << "please input n" << endl;
28     int n;
29     cin >> n;
30     cout << "The reslut: " << fibonacci(n) << endl;
31 
32     getchar();
33     getchar();
34     return 0;
35 }

 

经典算法详解(1)斐波那契数列的n项

标签:The   详解   整数   iostream   空间   系统   nbsp   argv   stream   

原文地址:https://www.cnblogs.com/ys99/p/9195507.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!