Python编程之欧拉计划(1-10)

欧拉计划

欧拉计划(Project Euler)看看能做到啥地步。

1、可被3或5整除的自然数之和

求小于1000的所有自然数中,可被3或5整除的数字之和。

# 求小于1000的所有自然数中可被3或5整除的数字之和
print(sum(i for i in range(1000) if i % 3 == 0 or i % 5 == 0))

输出:
233168

2、斐波那契数列中所有偶数之和

求不大于4000000的斐波那契数列中所有偶数之和。

# 斐波那契数列生成器
def fibonacci(n):
    yield 1
    a, b = 1, 2
    while b < n:
        yield b
        a, b = b, a + b

# 数列中的偶数求和
print(sum(x for x in fibonacci(4000000) if x % 2 == 0))

输出:
4613732

3、求600851475143的最大质因数

最大质因数不会大于平方根,所以从平方根倒推回去,能整除又是质数就是答案。

# 判断n是否质数,质数返回True
def isprime(n):
    if n == 2:
        return True
    elif n < 2 or n % 2 == 0:
        return False
    for i in range(3, int(n ** 0.5) + 1, 2):
        if n % i == 0:
            return False
    return 
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值