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

转载于:https://www.cnblogs.com/herbert/archive/2011/01/26/1945731.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值