用Python解答 ProjectEuler问题(2)

[b]E002[/b]
[i]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, ...

Find the sum of all the even-valued terms in the sequence which do not exceed four million.

找出不大于4,000,000的斐波那契数列中偶数值的总和。[/i]


def problem2():
a, b, c = 1, 2, 4*10**6

#掐头
if 0==a%2:
sum = 2*a
elif 0==b%2:
sum = 2*b
else:
sum = 0

while b<=c:
a, b = b, a+b
sum += b

#去尾
if 0!=b%2:
sum -= b
if 0!=a%2:
sum -= a

return sum/2

if __name__=='__main__':
print str(problem2())
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值