当前位置: 首页 > news >正文

leetcode.204.计数质数

#中等#枚举

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

埃氏筛


枚举没有考虑到数与数的关联性,因此难以再继续优化时间复杂度。接下来我们介绍一个常见的算法,该算法由希腊数学家厄拉多塞(Eratosthenes)提出,称为厄拉多塞筛法,简称埃氏筛。

我们考虑这样一个事实:如果 x 是质数,那么大于 x 的 x 的倍数 2x,3x,… 一定不是质数,因此我们可以从这里入手。

我们设 isPrime[i] 表示数 i 是不是质数,如果是质数则为 1,否则为 0。从小到大遍历每个数,如果这个数为质数,则将其所有的倍数都标记为合数(除了该质数本身),即 0,这样在运行结束的时候我们即能知道质数的个数。

这种方法的正确性是比较显然的:这种方法显然不会将质数标记成合数;另一方面,当从小到大遍历到数 x 时,倘若它是合数,则它一定是某个小于 x 的质数 y 的整数倍,故根据此方法的步骤,我们在遍历到 y 时,就一定会在此时将 x 标记为 isPrime[x]=0。因此,这种方法也不会将合数标记为质数。

当然这里还可以继续优化,对于一个质数 x,如果按上文说的我们从 2x 开始标记其实是冗余的,应该直接从 x⋅x 开始标记,因为 2x,3x,… 这些数一定在 x 之前就被其他数的倍数标记过了,例如 2 的所有倍数,3 的所有倍数等。

官方题解

class Solution {
public:int countPrimes(int n) {vector<int> isPrime(n, 1);int ans = 0;for (int i = 2; i < n; ++i) {if (isPrime[i]) {ans += 1;if ((long long)i * i < n) {for (int j = i * i; j < n; j += i) {isPrime[j] = 0;}}}}return ans;}
};//官方题解​

class Solution {
public:int countPrimes(int n) {vector<int> primes;vector<int> isPrime(n, 1);for (int i = 2; i < n; ++i) {if (isPrime[i]) {primes.push_back(i);}for (int j = 0; j < primes.size() && i * primes[j] < n; ++j) {isPrime[i * primes[j]] = 0;if (i % primes[j] == 0) {break;}}}return primes.size();}
};作者:力扣官方题解
链接:https://leetcode.cn/problems/count-primes/solutions/507273/ji-shu-zhi-shu-by-leetcode-solution/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
class Solution {
public:int countPrimes(int n) {vector<int>isPrime(n,1);//线性筛vector<int>prime;for(int i=2;i<n;i++){if(isPrime[i]){prime.push_back(i);}for(int j=0;j<prime.size()&&prime[j]*i<n;j++){isPrime[prime[j]*i]=0;if(i%prime[j]==0)break;}}return prime.size();}
};

http://www.lryc.cn/news/463370.html

相关文章:

  • Mysql环境安装
  • 请问平面仓系统的盘点如何做?
  • STM32笔记(1)GPIO之点亮LED
  • 自动化工具
  • CTFHUB技能树之HTTP协议——响应包源代码
  • Java会话技术,拦截器,过滤器,登录校验
  • Spring Security 如何进行权限验证
  • 计算机砖头书的学习建议
  • 我与C语言二周目邂逅vlog——7.预处理
  • Python无监督学习中的聚类:K均值与层次聚类实现详解
  • C++ 中 new 和 delete 详解,以及与 C 中 malloc 和 free 的区别
  • YOLOv11来了 | 自定义目标检测
  • Vue3 集成Monaco Editor编辑器
  • 一文详解Mysql索引
  • 基于JAVA+SpringBoot+Vue的旅游管理系统
  • STM32_实验3_控制RGB灯
  • RISC-V笔记——Pipeline依赖
  • 构建后端为etcd的CoreDNS的容器集群(六)、编写自动维护域名记录的代码脚本
  • Leetcode 剑指 Offer II 098.不同路径
  • LabVIEW智能螺杆空压机测试系统
  • 在 Ubuntu 22.04 上安装 PHP 8.2
  • Java生死簿管理小系统(简单实现)
  • 【VoceChat】一个即时聊天(IM)软件,又是一个可以嵌入任何网页聊天系统
  • 【LeetCode】动态规划—96. 不同的二叉搜索树(附完整Python/C++代码)
  • Nginx UI 一个可以管理Nginx的图形化界面工具
  • Vue向上滚动加载数据时防止内容闪动
  • 基于QT、ARM的智能停车管理系统+高分项目+源码
  • 1.6,unity动画Animator屏蔽某个部位,动画组合
  • 发动机冷却系统排空气
  • 三周精通FastAPI:1 第一步入门