判断一个数是否为素数的简单方法
素数(质数)的定义:一个大于1的自然数,除了1和它自身外,不能被其他自然数整除的数叫做质数;否则称为合数(规定1既不是质数也不是合数)。
假设有数字n,由素数的定义可知,n只可以被1和a整除(也即n仅有1和n两个因数)。
思路1:利用循环,在范围[2, n-1]内进行操作,具体操作是n被范围[2, n-1]内所有的数整除,若余数均为0则说明n是素数(或者说是n不可以被这个范围的数整除)。 (注意:范围两端2与n-1均可以取到)
python示例如下:
根据范围的不用可以分别将循环的范围改为 [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)。
思路二待完善,读者需自行查询资料了解,此处思路仅供参考。