算法(TS):计数质数

给定整数 n ,返回 所有小于非负整数 n 的质数的数量 。

示例 1:

输入:n = 10

输出:4

解释:小于 10 的质数一共有 4 个, 它们是 2, 3, 5, 7 。

示例 2:

输入:n = 0

输出:0

示例 3:

输入:n = 1

输出:0

提示:

  • 0 <= n <= 5 * 106

解法一:枚举求解

考虑质数的定义:在大于 1 的自然数中,除了 1 和它本身以外不再有其他因数的自然数。因此对于任何整数n,我们都能从小到大枚举[2,n-1]中的 x,判断 x 是否能被 n 整除,如果能,则n是质数。这里的时间复杂度为O(n)。继续考虑,如果 x 能被 n 整除,那么 n/x 也能被 n 整除,因此只需要校验 x 或者 n/x 就能判断 n 是不是质数。Math.min(n/x,x)一定落在[2,Math.sqrt(x)] 的区间中,因此对于整数 n,只需要判断[2,Math.sqrt(x)]是否有因子即可。这样单次检测的事件复杂度从O(n)减低到O(Math.sqrt(n))。

返回所有小于非负整数 n 的质数的数量,只需要判断从 2 到 n-1 的数是否是质数。

typescript 复制代码
function isPrime(n:number) {
    for(let i = 2; i * i <= n; i++) {
        if(n%i===0) {
            return false
        }
    }

    return true
}

function countPrimes(n: number): number {
    let count = 0

    for(let i = 2; i < n; i++) {
        if(isPrime(i)){
            count++
        }
    }

    return count
}

解法二:埃氏筛

如果 x 是质数,那么 x 的 j 倍,例如 2x,3x... 一定不是质数,利用可以从这里入手优化时间复杂度。

ini 复制代码
function countPrimes(n: number): number {
    const isPrimeArr = new Array(n).fill(1)
    let count = 0

    for(let i = 2; i < n; i++) {
        if(isPrimeArr[i]) {
            count++
            for(let j = 2;i * j < n;j++) {
                isPrimeArr[i * j] = 0
            }
        }
    }

    return count
}

时间复杂度:O(nlog⁡log⁡n),空间复杂度:O(n)。

相关推荐
老赵聊算法、大模型备案5 小时前
北京市生成式人工智能服务已备案信息公告(2025年12月11日)
人工智能·算法·安全·aigc
CoderYanger6 小时前
C.滑动窗口-求子数组个数-越长越合法——2799. 统计完全子数组的数目
java·c语言·开发语言·数据结构·算法·leetcode·职场和发展
厕所博士6 小时前
红黑树原理前置理解—— 2-3 树
算法·2-3树·红黑树原理理解前置
萌>__<新6 小时前
力扣打卡每日一题————除自身外所有元素的乘积
数据结构·算法
xu_yule7 小时前
算法基础—搜索(2)【记忆化搜索+BFS+01BFS+Floodfill]
数据结构·算法
s09071367 小时前
Xilinx FPGA使用 FIR IP 核做匹配滤波时如何减少DSP使用量
算法·fpga开发·xilinx·ip core·fir滤波
老马啸西风7 小时前
成熟企业级技术平台-10-跳板机 / 堡垒机(Bastion Host)详解
人工智能·深度学习·算法·职场和发展
子夜江寒7 小时前
逻辑回归简介
算法·机器学习·逻辑回归
软件算法开发7 小时前
基于ACO蚁群优化算法的多车辆含时间窗VRPTW问题求解matlab仿真
算法·matlab·aco·vrptw·蚁群优化·多车辆·时间窗
another heaven8 小时前
【软考 磁盘磁道访问时间】总容量等相关案例题型
linux·网络·算法·磁盘·磁道