[Project Euler]加入欧拉 Problem 2

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));
}

你可能感兴趣的:(project)