鱼C论坛

 找回密码
 立即注册
查看: 1775|回复: 4

[已解决]以下100以内的质数代码求高手详细解释

[复制链接]
发表于 2018-4-16 00:04:23 | 显示全部楼层 |阅读模式

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

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

x
x = [i for i in range(2, 100) if [] == [j for j in range(2, i // 2 + 1) if i % j == 0]]
最佳答案
2018-4-16 09:12:23
等价于
  1. x = []
  2. for i in range(2,100):
  3.     for j in range(2,i//2+1):
  4.         if i % j == 0:
  5.             break
  6.     else:
  7.         x.append(i)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2018-4-16 09:12:23 | 显示全部楼层    本楼为最佳答案   
等价于
  1. x = []
  2. for i in range(2,100):
  3.     for j in range(2,i//2+1):
  4.         if i % j == 0:
  5.             break
  6.     else:
  7.         x.append(i)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2018-4-16 09:39:13 | 显示全部楼层
求质数的三个方案:
1.对于数字n,我们可以从2开始,直到n-1,试除每一个数字。
如果都不能整除n,那么n就是质数了!
2.如果n不是偶数的话,我们只需要从3开始,只试除3、5、7这样的奇数就好了。
3.数学知识:我们只需要试除到n的算术平方根,如果都没有能整除它的数,那么就能判断这个数是质数了。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-16 10:34:50 From FishC Mobile | 显示全部楼层
BngThea 发表于 2018-4-16 09:12
等价于

可以注解下吗
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-16 11:04:03 | 显示全部楼层

对100以内的数据循环
    如果该数有大于等于2且小于等于该数除以2加1的因子,说明该数不是素数
    如果上述循环结束都没break,说明没有找到因子,该数是素数,添加到x中
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-3-10 15:04

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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