【lc刷题】204 计数质数_Day47(132/300)

132/300

  1. 计数质数
    统计所有小于非负整数 n 的质数的数量。
     
    示例:
     
    输入: 10
    输出: 4
    解释: 小于 10 的质数一共有 4 个, 它们是 2, 3, 5, 7 。

思路:厄拉多塞筛法

sieve of Eratosthenes:给素数的倍数灭灯
在这里插入图片描述
图源:wikimedia

Time complexity: O(nloglogn); Space complexity: O(n)

遍历不需要从 2 ~ N, 只需要从 2 ~ N \sqrt{N} N
对于合数N = N × N \sqrt{N}\times\sqrt{N} N ×N = d1 × \times × d2
推出 d1 <= N \sqrt{N} N or d2 <= N \sqrt{N} N

举例:
119 = 7 × \times × 17 ; 119 \sqrt{119} 119 = 10.908
7的倍数, 119被灭

关于如何灭灯:需要用到Python 字符串/列表 切片slice的知识

class Solution:
    def countPrimes(self, n: int) -> int:
 
        if n < 3: return 0
        
        res = [ 1 for _ in range(n) ]
        
        res[0], res[1] = 0,  0

        for i in range(2, int(n**0.5) + 1): 

            res[i*i::i] = len(res[i*i::i])*[0]
 
        return sum(res)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值