njchenzh 2022-07-20 16:35 采纳率: 100%
浏览 31
已结题

使用python列出1-100的素数,请问这个m参数有什么用?

这是模板代码。
我感觉把m参数去掉,while循环和if判断的m都改为n,也是可以得出结果的,请问m参数在代码中有什么作用吗?

#python 列出1-100的素数
for n in range(2,101):
    m = float(n ** 0.5)
    i = 2
    while i <= m:
        if n % i == 0:
            break
        i += 1
    if i > m:
        print(n,end=' ') 

  • 写回答

3条回答 默认 最新

  • 快乐鹦鹉 2022-07-20 16:39
    关注

    m的作用就是降低可能的循环次数,m值为n开根号
    比如要判断17是不是素数,根据素数的定义,那么就是从2到16全部与17进行求余判断,有1个为0就表示17不是素数,这样需要判断16次
    但实际上,只需要判断到17开根号,即4即可,也就是只需要判断17求余2、3和4是否为0就可以了。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 7月28日
  • 已采纳回答 7月20日
  • 创建了问题 7月20日

悬赏问题

  • ¥15 路易威登官网 里边的参数逆向
  • ¥15 Arduino无法同时连接多个hx711模块,如何解决?
  • ¥50 需求一个up主付费课程
  • ¥20 模型在y分布之外的数据上预测能力不好如何解决
  • ¥15 processing提取音乐节奏
  • ¥15 gg加速器加速游戏时,提示不是x86架构
  • ¥15 python按要求编写程序
  • ¥15 Python输入字符串转化为列表排序具体见图,严格按照输入
  • ¥20 XP系统在重新启动后进不去桌面,一直黑屏。
  • ¥15 opencv图像处理,需要四个处理结果图