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]
}