算法-计数质数

题目:

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

思路:

使用埃式筛法

当n大于等于2时,如果当前遍历的数 i 是质数,那么从 i*i 开始,直到 n 为止,把 i 的倍数都标记为合数

代码:

cpp 复制代码
class Solution {
public:
    int countPrimes(int n) {
        if(n <= 2) return 0;
        vector<bool> isPrime(n + 1, true);
        for(int i = 2; i < n; i++){
            if(isPrime[i]){
                for(int j = i; j <= n / i; j++){
                    isPrime[i * j] = false;
                }
            }
        }

        int res = 0;
        for(int i = 2; i < n; i++){
            if(isPrime[i]) res++;
        }

        return res;
    }
};
相关推荐
ullio6 分钟前
div1+2. 2178F - Conquer or of Forest
算法
Leweslyh19 分钟前
制导算法开发实践指南:从入门到精通
算法·开发·武器·制导律设计
chushiyunen21 分钟前
快慢双指针算法笔记
数据结构·笔记·算法
烟锁池塘柳034 分钟前
一文总结模型压缩技术:剪枝、量化与蒸馏的原理、实践与工程思考
算法·机器学习·剪枝
独自破碎E36 分钟前
Leetcode1438绝对值不超过限制的最长连续子数组
java·开发语言·算法
東雪木1 小时前
编程算法学习——数组与排序算法
学习·算法
你撅嘴真丑1 小时前
方格取数 矩阵取数游戏 -动态规划
算法·动态规划
前端小L1 小时前
贪心算法专题(十三):画地为牢的艺术——「划分字母区间」
javascript·算法·贪心算法
@小码农1 小时前
202512 电子学会 Scratch图形化编程等级考试三级真题(附答案)
服务器·开发语言·数据结构·数据库·算法
橘颂TA2 小时前
【剑斩OFFER】算法的暴力美学——重排链表
算法·结构与算法