python中判断素数的几种方法

用python统计101~200中素数的个数,并且输出所有的素数。

分析:这是一道典型的循环题。首先,我们应该考虑101~200中得每一个都需要判断是否为素数;其次,每一个数在判断为素数时都需要判断能不能被1和它本身以外的数整除。所以这道题,我们在编写程序的时候要用嵌套循环。

  1. for循环编写程序:
    方法一:
    for i in range(101, 200):
        for j in range(2, i//2):
            if i % j == 0:
                break
            elif j == i // 2 - 1:
                print(i)
            else:
                continue
    

    注意事项:

    1. 在编写python程序的时候需要注意range(a,b) ,这是一个前闭后开区间,取a不取b
    2. 当我们在判断每一个数x是否是素数的时候,我们只需要计算这个数能不能被[2,x/2]之间的数整除即可
    3. 当我们判断一个数x不能被整除后,就用关键字break结束此次循环(注意区分break和continue)
    方法二:
    for i in range(101, 200):
        for j in range(2, i//2+1):
            if i % j == 0:
                break
        else:
            print(i)
    

    注意事项:

    1. 此方法中与else对应的if条件为空,也就是第二个for循环的内容相当于if的条件和内容
    方法三:
    for i in range(100, 200):
        s = 0
        for j in range(2, i):
            if i % j != 0:
                s += 1
                continue
            else:
                break
        if s == i - 2:
            print(i)
    

    注意事项:

    1. 对每一个数进行求余,如果不能够整除,则对s加一,对该数的判断结束后,进行判断:s == i-2(对除1和自身以外数进行判断)
    方法四:
    for i in range(101, 200):
        list01 = []
        for j in range(2, i):
            list01.append(str(i % j))
        if "0" not in list01:
            print(i)
    

    注意事项:

    1. 这种方法是在方法三的基础上改进的,对每个数求余的结果存入列表中,再判断0是否在列表中即可。
有很多不同的方法可以用 Python 生成素数,以下是其几个常见的方法: 1. 暴力枚举法: 这种方法的思路是从 2 开始遍历所有的自然数,判断其是否为素数。具体实现可以使用两个嵌套的循环,外层循环枚举自然数,内层循环用于判断是否为素数。代码示例: ```python def is_prime(n): if n <= 1: return False for i in range(2, n): if n % i == 0: return False return True def generate_primes(n): primes = [] for i in range(2, n): if is_prime(i): primes.append(i) return primes ``` 2. 厄拉多塞筛法: 这种方法的基本思路是从小到大枚举自然数,如果该数为素数,则将其所有的倍数都标记为合数。具体实现可以使用一个布尔数组来记录每个数是否为素数,初始时所有数都为素数,然后从 2 开始枚举,如果当前数为素数,则将其所有的倍数都标记为合数。代码示例: ```python def generate_primes(n): is_prime = [True] * n primes = [] for i in range(2, n): if is_prime[i]: primes.append(i) for j in range(i * i, n, i): is_prime[j] = False return primes ``` 3. 线性筛法: 这种方法是一种优化过的厄拉多塞筛法,其基本思路是从小到大枚举自然数,如果该数为素数,则将其直接加入素数列表,并且将其所有的倍数都标记为合数。如果当前数是某个素数的倍数,则直接跳过。具体实现可以使用一个数组记录每个数的最小素因子,初始时所有数的最小素因子都为自身,然后从 2 开始枚举,如果当前数的最小素因子是自身,则将其加入素数列表,并将其所有的倍数的最小素因子都更新为该素数。代码示例: ```python def generate_primes(n): is_prime = [True] * n primes = [] min_factors = [0] * n for i in range(2, n): if is_prime[i]: primes.append(i) min_factors[i] = i for j in range(len(primes)): if primes[j] > min_factors[i] or primes[j] * i >= n: break is_prime[primes[j] * i] = False min_factors[primes[j] * i] = primes[j] return primes ``` 以上是三个常见的生成素数的方法,实际上还有很多其他的方法可以用于生成素数。
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值