首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Lucas-Lehmer Mersenne数与Python

Lucas-Lehmer Mersenne数与Python
EN

Stack Overflow用户
提问于 2019-04-28 23:59:56
回答 1查看 678关注 0票数 1

编写Python代码,使用Lucas-Lehmer测试检查Mersenne数。

代码语言:javascript
复制
def lucas_lehmer(p):
 my_list=[4]
 value=2**p-1
 lucas=4
 for val in range(1, p - 1):
    lucas=(lucas*lucas-2)%value
 if lucas== 0:
        my_list.apprend(lucas)
 else: 
  break
 print(my_list)
 print(lucas)

上面显示的代码只给出了第一次迭代的结果,而不考虑所选的p值。我希望能够显示p给定值内的所有Lehmer测试值,在本例中为17。

EN

回答 1

Stack Overflow用户

发布于 2019-04-29 00:15:03

如果我没理解错你的问题,我认为问题不是在循环中进行追加,而是只有当p是质数时。您的格式有点不正确,所以我不能100%确定我是否正确。此外,您在append中有一个拼写错误。我添加了一些代码来打印素数测试的实际结果。

代码语言:javascript
复制
def lucas_lehmer(p):
    my_list=[4]
    value=2**p-1
    lucas=4
    for val in range(1, p - 1):
        lucas = ((lucas*lucas)-2) % value
        my_list.append(lucas)
    if lucas == 0:
        print("prime")
    else:
        print("composite")
    print(my_list)
    print(lucas)

调用lucas_lehmer(7)将导致以下输出:

代码语言:javascript
复制
prime
[4, 14, 67, 42, 111, 0]
0
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55892021

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档