Project Euler Problem 46

本文探讨了哥德巴赫的一个猜想:每个奇合数可以表示为一个素数加上一个平方数的两倍。通过编程验证了该猜想的错误,并找出最小的无法用这种方式表达的奇合数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Problem 46

It was proposed by Christian Goldbach that every odd composite number can be written as the sum of a prime and twice a square.

9 = 7 + 2×12
15 = 7 + 2×22
21 = 3 + 2×32
25 = 7 + 2×32
27 = 19 + 2×22
33 = 31 + 2×12

It turns out that the conjecture was false.

What is the smallest odd composite that cannot be written as the sum of a prime and twice a square?

克里斯蒂安·哥德巴赫曾经猜想,每个奇合数可以写成一个素数和一个平方的两倍之和。

9 = 7 + 2×12
15 = 7 + 2×22
21 = 3 + 2×32
25 = 7 + 2×32
27 = 19 + 2×22
33 = 31 + 2×12

最终这个猜想被推翻了。

最小的不能写成一个素数和一个平方的两倍之和的奇合数是多少?


def isprime(x):
    if x <= 1:
        return False
    for i in range(2,int(x**0.5+1)):
        if x % i == 0:
            return False
    return True

odd = {2*n+1 for n in range(10000) if not isprime(2*n+1)}
primes = [x for x in range(10000) if isprime(x)]
product = set()
for i in primes:
    for j in range(1,1000):
        product.add(i + 2*j**2)
for k in odd:
    if k not in product:
        print(k)
          

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值