题目一:写一个函数,输入n,求斐波那契(Fibonacci)数列的第n项。
解析:一直以来很多C语言教科书在讲递归函数的时候总会拿斐波那契数列作为例子。但是这不意味这Fibonacci的最合适的解法就是用递归来实现。如果面试问道这题然后用递归解,那基本就GG了。因为递归调用过程中有很多重复计算,而且重复的数量随着n的增加而剧增,实际上斐波那契递归时间复杂度是以n的指数级的方式递增,计算F(100)估计等到花儿都谢了。
其实观察数列就不难发现,只要有前两项就能算出下一项,如f(0), f(1)计算出f(2), f(1), f(2)计算出f(3)以此类推,这样就能用循环计算出第n项的值。时间复杂度O(n).
代码:
#include <iostream>
using namespace std;
//非递归求斐波那契第n项O(n)
long long Fib(unsigned n)
{
if (n =&