Each new term in the Fibonacci sequence is generated by adding the previous two terms. By starting with 1 and 2, the first 10 terms will be:
1, 2, 3, 5, 8, 13, 21, 34, 55, 89, ...
By considering the terms in the Fibonacci sequence whose values do not exceed four million, find the sum of the even-valued terms.
求Fibonacci数列里面偶数项的和
哥就暴力求解,无需技巧,计算机算的够快,没问题^_^
#include <stdio.h>
#include <stdlib.h>
double Fib(int n); //求第n个Fibonacci数列的值
int main(int argc, char *argv[])
{
// 求出 < 4,000,000 对应的最大的Fib的n
double fib = 0.0;
int n = 1;
while(fib < 4000000)
{
fib = Fib(n);
n++;
}
// 暴力求解相加的和
double sum = 0.0;
int i = 2;
while(i < n)
{
sum += Fib(i);
i += 3;
}
printf("%lf", sum);
system("PAUSE");
return 0;
}
double Fib(int n)
{
if(n == 1)
return 1;
if(n == 2)
return 2;
else
return(Fib(n-2) + Fib(n-1));
}