判断一个数是否为素数的简单方法

判断一个数是否为素数的简单方法

  素数(质数)的定义:一个大于1的自然数,除了1和它自身外,不能被其他自然数整除的数叫做质数;否则称为合数(规定1既不是质数也不是合数)。

质数表(1000以内)

图1 质数表(1000以内)

假设有数字n,由素数的定义可知,n只可以被1和a整除(也即n仅有1和n两个因数)。
思路1:利用循环,在范围[2, n-1]内进行操作,具体操作是n被范围[2, n-1]内所有的数整除,若余数均为0则说明n是素数(或者说是n不可以被这个范围的数整除)。 (注意:范围两端2与n-1均可以取到)
python示例如下:
python判断素数

图2 判断素数(此处范围为[2, n-1])

   根据范围的不用可以分别将循环的范围改为 [2, n-1], [2, n 2 \frac{n}{2} 2n], [2, n \sqrt{n} n ] ,根据具体的需求将范围进行修改(常用的较为精确的范围实际为 :[2, n \sqrt{n} n ])。
此外,还有普通筛法——埃拉托斯特尼(Eratosthenes)筛法如下(即思路2):
思路2:
  1) 创建一个比范围上限大1的数组,但要仅关注下标为 1 ~ n(要求的上限)的数组元素与数组下标(一 一对应);
  2) 将数组初始化为1,然后用for循环,遍历范围为[2 ~ sqrt(n)]。如果数组元素为1,则说明这个数组元素的下标所对应的数是素数。
  3) 随后我们将这个下标(除1以外)的整数倍所对应的数组元素全部置为0,也就是判断其为非素数。
按照上述步骤在范围(1 ~ 范围上限n)所有数是素数(下标对应的数组元素值为1)或不是素数(下标对应的数组元素值为0)。

思路二待完善,读者需自行查询资料了解,此处思路仅供参考。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值