欧拉项目(python练习)problem 46

来源:互联网 发布:知乎 儿童 天文望远镜 编辑:程序博客网 时间:2024/06/18 15:02
# -*- coding:utf8 -*-import sysfrom math import sqrtimport decide_whether_prime#题目设置'''Christian Goldbach 提出每个奇合数都可以写作一个质数与一个平方数的二倍之和:9 = 7 + 2×1215 = 7 + 2×2221 = 3 + 2×3225 = 7 + 2×3227 = 19 + 2×2233 = 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 mathdef 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

0 0