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);
}
}问题细节: Fibonacci序列中的每个新项都是通过将前两个项相加而生成的。从1和2开始,前10个术语将是:
1,2,3,5,8,13,21,34,55,89,...
通过考虑Fibonacci序列中值不超过400万的项,求出偶数值项的总和
我得到了2851443的答案,并且我检查了我的代码很多次。
发布于 2017-03-01 14:06:05
此代码中存在一个问题:
if (term[1]%2==0)
{sum=sum+term[0];}如果检测到term1为偶数,则应将其添加到总和中,而不是前一个值:
if (term[1] % 2 == 0) {
sum = sum + term[1]; // add term[1], not term[0]
}https://stackoverflow.com/questions/42524280
复制相似问题