Euler project #2

  • 本文关键字:project Euler java
  • 更新时间 :
  • 英文 :

public class Fibonaccisequence {
    public static void main(String args[]){
        int term[] = new int[]{1,2};
        int termValue = term[0]+term[1];
        int sum = 0;
        while(termValue <= 4000000)
        {
            termValue = term[0]+term[1];
            if (term[1]%2==0)
            {sum=sum+term[0];}

            int a= term[1];
            term[1]=termValue;
            term[0]=a;
        }
        System.out.println(sum);
    }
 }

问题细节:斐波那契序列中的每个新术语都是通过添加前两个项生成的。从1和2开始,前10个术语将是:

1、2、3、5、8、13、21、34、55、89,...

通过考虑斐波那契序列中的术语,其值不超过400万,找到偶数术语的总和

我得到了2851443的答案,我多次检查了我的代码。

在此代码中存在问题:

if (term[1]%2==0)
{sum=sum+term[0];}

如果您检测到该术语[1],则应该将其添加到总和中,而不是以前的值:

if (term[1] % 2 == 0) {
    sum = sum + term[1];  // add term[1], not term[0]
}

最新更新