欧拉项目(python练习)problem 46

本文探讨了Python在欧拉项目中的应用,具体聚焦于问题46,通过`decide_whether_prime`函数找寻特定素数,最终得出运行结果5777。
摘要由CSDN通过智能技术生成
# -*- coding:utf8 -*-

import sys
from math import sqrt

import decide_whether_prime

#题目设置
'''Christian Goldbach 提出每个奇合数都可以写作一个质数与一个平方数的二倍之和:

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

但是这个推测是错误的。

最小的不能写作一个质数与一个平方数的二倍之和的奇合数是多少?'''

#解题思路:首先创建一个方法,判断一个奇合数能否被以题目中的方式分解,之后从9开始,对所有的奇合数进行判断,就利用刚才创建的方法,直到找到这个不能被分解的奇合数为止

class MinimumUndividedNumber():                                               #定义了一个找到最小的不能分解的奇合数的类

    def __init__(self):
        pass
      
    def judge_whether_divided(self , odd_composite_number):                   #创建了一个方法,判断奇合数是否能被分解,能则返回1,否则返回0
        can_be_divided = 0
        for number in range(3 , odd_composite_number , 2):
            if decide_whether_prime.decide_whether_prime(number) == 1:
                if sqrt((odd_composite_number - number) / 2) % 1 == 0:
                    can_be_divided = 1
                    break
        return can_be_divided
                    
    def find_minimum_number(self):                                            #主方法,找到最小的不能分解的奇合数,从9开始,逐个判断
        odd_number = 9
        while(True):
            if decide_whether_prime.decide_whether_prime(odd_number) == 0:
                if self.judge_whether_divided(odd_number) == 0:
                    return odd_number
            odd_number = odd_number + 2
            
if __name__ == "__main__":
    minimum_undivided_number = MinimumUndividedNumber()
    print minimum_undivided_number.find_minimum_number()



decide_whether_prime:

# -*- coding:utf8 -*-

import math

def decide_whether_prime(number):
    is_prime = 1
    if number == 1:
        is_prime = 0
    if number == 2 :
        pass
    else :
        for divisor in range(2 , int(math.sqrt(number)) + 1):
            if number%divisor == 0:
                is_prime = 0
                break
    return is_prime


运行结果:5777

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值