鱼C论坛

 找回密码
 立即注册
查看: 2774|回复: 2

[已解决]Python 判断素数,两个小问题

[复制链接]
发表于 2021-4-1 16:55:49 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 Peteryo01223 于 2021-4-1 17:09 编辑

原题:判断素数

答案:如下(我自己写的注释):
  1. import math # 导入math模块

  2. def is_prime(number): # 定义函数名称
  3.     if number > 1: # 设定取值范围为正整数
  4.         if number == 2: # 单独把 2 认定为素数
  5.             return True
  6.         if number % 2 == 0: # 排除所有偶数,减少计算量
  7.             return False
  8.         for current in range (3, int(math.sqrt(number) + 1),2): # 从3开始,在number开平方的结束,步幅是2。但是,为什么要加一?
  9.             if number % current == 0:
  10.         # 公元250 BC,古希腊数学家埃拉托塞尼提出:“要得到不大于某个自然数 N 的所有素数
  11.         # 只要在2 至 N中,将不大于的素数的倍数全部划去即可”。
  12.         # 内容等价转换:如果N是合数,则它有一个因子d满足1<d≤sqrt N
  13.                 return False
  14.         return True # ? 何意?
  15.     return False
复制代码


问题:
1. 第9句,为何要加一?
2. 第15句和上面哪一句呼应?为何突然出现一个return True,没看懂。
最佳答案
2021-4-1 17:55:02
1、对于语句
  1. for c in range(a , b)
复制代码

     循环中,c 值最大只能到 b - 1,所以
  1. for current in range (3, int(math.sqrt(number) + 1),2):
复制代码

      加 1 是为了让 current 的最大值能等于 int(math.sqrt(number))
2、return 是用来结束函数调用,反馈调用结果的。在 for 循环内有一个 return False,意思是进入循环前,假定 number 是一个素数,然后,试图在 for 循环内进行否定,就是说,如果在循环中找到了 number 的因数,那么,number 就不是素数,这时,执行 return False,函数调用随之结束;如果 for 循环可以被顺利地执行完(而没有执行 return False),那么,就说明 number 确实就是一个素数,所以,return True
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-4-1 17:55:02 | 显示全部楼层    本楼为最佳答案   
1、对于语句
  1. for c in range(a , b)
复制代码

     循环中,c 值最大只能到 b - 1,所以
  1. for current in range (3, int(math.sqrt(number) + 1),2):
复制代码

      加 1 是为了让 current 的最大值能等于 int(math.sqrt(number))
2、return 是用来结束函数调用,反馈调用结果的。在 for 循环内有一个 return False,意思是进入循环前,假定 number 是一个素数,然后,试图在 for 循环内进行否定,就是说,如果在循环中找到了 number 的因数,那么,number 就不是素数,这时,执行 return False,函数调用随之结束;如果 for 循环可以被顺利地执行完(而没有执行 return False),那么,就说明 number 确实就是一个素数,所以,return True
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-4-1 17:57:17 | 显示全部楼层
jackz007 发表于 2021-4-1 17:55
1、对于语句

     循环中,c 值最大只能到 b - 1,所以

谢谢您的耐心解答~
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-25 03:41

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表