【算法基础】筛质数

文章目录

  • 问题描述
  • 解决方法
    • 朴素筛法
    • 线性筛法

在这里插入图片描述


问题描述

给定一个正整数 n n n,请你求出 1 ∼ n 1∼n 1n 中质数的个数。

输入格式
共一行,包含整数 n。

输出格式
共一行,包含一个整数,表示 1∼n 中质数的个数。

数据范围
1 ≤ n ≤ 1 0 6 1≤n≤10^6 1n106


解决方法

朴素筛法

从前往后遍历,把每个数的倍数都删掉,剩下的数就是质数
证明方法在前面的一个打卡里面写了,复杂度是O(nlogn)
这里优化一下,只需要把所有质数的倍数删掉即可,证明也是在上一篇文章里面讲了
这里是时间复杂度为O(nloglogn),这里把它叫做埃氏筛法

代码实现

#include<iostream>
#include<algorithm>
using namespace std;const int N = 1000010;
bool st[N];
int cnt, primes[N];int get_primes(int n){for(int i = 2; i <= n; i++){if(!st[i]){primes[cnt++] = i;for(int j = i + i; j <= n; j += i) st[j] = true;}}return cnt;
}int main(){int n;cin >> n;int res = get_primes(n);cout << res << endl;return 0;
}

线性筛法

思想:把每一个合数用它的某一个质因子筛掉即可
每个合数x一定会被筛掉,而且筛的时候一定用的是最小质因子,
而且每个数只有一个最小质因子,所以每个数只会被筛一次,所以是线性的。

代码实现

#include<iostream>
#include<algorithm>
using namespace std;const int N = 1000010;
bool st[N];
int cnt, primes[N];int get_primes(int n){for(int i = 2; i <= n; i++){if(!st[i]) primes[cnt++] = i;   //如果是质数,把它放到数表里面去//从小到大枚举所有的质数for(int j = 0; primes[j] <= n / i; j++){st[primes[j] * i] = true;       //把primes[j]这个质数的某个倍数筛掉即可(核心思想)//这个合数是前面某一个质数的倍数,已经筛掉了if(i % primes[j] == 0) break;   //(因为是从小到达枚举的所有的质数,所以第一次出现的primes[j]一定是i的最小质因子)}}return cnt;
}int main(){int n;cin >> n;int res = get_primes(n);cout << res << endl;return 0;
}

作者:为梦而生
链接:https://www.acwing.com/file_system/file/content/whole/index/content/10509230/
来源:AcWing
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/154314.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

完美解决k8s master节点无法ping node节点中的IP或Service NodePort的IP

1、问题一 使用搭建好了K8S集群&#xff0c;先是node节点加入k8s集群时&#xff0c;用的内网IP&#xff0c;导致master节点无法操作node节点中的pod&#xff08;这里的不能操作&#xff0c;指定是无法查看node节点中pod的日志、启动描述、无法进入pod内部&#xff0c;即 kubec…

【GCN】GCN学习笔记一

谱域图卷积 卷积 卷积定义离散空间的卷积 图卷积简介 卷积定理谱域图卷积实现思路如何定义图上的傅里叶变换拉普拉斯矩阵 &#xff08;Laplacian Matrix&#xff09;拉普拉斯矩阵的性质拉普拉斯矩阵的谱分解拉普拉斯矩阵与拉普拉斯算子 图傅里叶变换 图上的信号表示经典傅里叶变…

Python Web框架的三强之争:Flask、Django和FastAPI

JetBrains 公布 2022 Python 开发者调查结果。 完整报告地址&#xff1a;https://lp.jetbrains.com/zh-cn/python-developers-survey-2022/ 这是由 Python 软件基金会 (PSF) 和 JetBrains 共同开展的第六次官方年度 Python 开发者调查&#xff0c;回复于 2022 年 10 月至 12 …

键鼠自动化2.0树形结构讲解

介绍 在键鼠自动化2.0中使用Qtc实现了全自定义树形结构&#xff0c;实现任务的拖拽&#xff0c;复制粘贴&#xff0c;撤销重做&#xff0c;以及包括树形结构增加序号展示&#xff0c;以及增加搜索功能 实现 1.自定义节点 // 自定义节点类 class TreeNode : public QObject …

2013年12月13日 Go生态洞察:Go在App Engine上的工具、测试和并发

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…

Java高级编程-----网络编程

网络通信协议 通过计算机网络可以实现多台计算机连接&#xff0c;但是不同计算机的操作系统和硬件体系结构不同&#xff0c;为了提供通信支持&#xff0c;位于同一个网络中的计算机在进行连接和通信时必须要遵守一定的规则&#xff0c;这就好比在道路中行驶的汽车一定要遵守交…

.NET 主流 ORM 功能介绍 大全 最新

.NET主流ORM 下面是3款.NET 使用最多的ORM 测试项目发布时间微信公众号投票 (追逐时间光者)使用难度功能SqlSugar orm201426% 491票适中全EFCore orm201636% 663票较难全Dapper orm201323% 374票简单少 一、SqlSugar ORM介绍 是一款 老牌 .NET 开源多库架构ORM框架…

mricorn 手动勾画ROI并保存为模版的方法步骤

mricorn软件手动勾画ROI&#xff1a; 这里拿一个做了切除手术的癫痫病人举例子&#xff0c;我们需要把切除区域勾画出来并保存成切除的模版。 1、将图像导入到mricorn中 2、逐层勾画ROI并填充 比较方便的是从切除区域的起始层进行勾画&#xff0c;这里为了方便展示只勾画中间…

计算机网络的OSI七层模型

目录 1、OSI七层模型是什么 1.1 物理层&#xff08;Physical Layer&#xff09; 1.2 数据链路层&#xff08;Data Link Layer&#xff09; 1.3 网络层&#xff08;Network Layer&#xff09; 1.4 传输层&#xff08;Transport Layer&#xff09; 1.5 会话层&#xff08;S…

如何进行并发编程和线程同步?

并发编程是一种多任务处理的编程范式&#xff0c;它允许程序中的多个任务&#xff08;线程、进程等&#xff09;在相同的时间段内执行。线程同步是确保这些并发任务在共享资源上正确协作的一种技术。在C语言中&#xff0c;通过使用线程和相关的同步机制&#xff0c;可以实现并发…

5款免费BI数据可视化工具,2023年最新精选推荐!

BI可视化工具顾名思义是进行数据分析和可视化的软件&#xff0c;旨在将数据以表格、图表、仪表盘等形式展示出来&#xff0c;让用户能够更加直观了解其业务状况、发现问题&#xff0c;并在必要时进行决策。   市面上BI数据可视化工具很多&#xff0c;目前比较火的像国外的Tabl…

应用软件安全编程--24不要使用硬编码密匙

当程序中使用硬编码加密密匙时&#xff0c;所有项目开发人员都可以查看该密匙&#xff0c;甚至如果攻击者能够获取 程序 class文件&#xff0c;可通过反编译得到密匙&#xff0c;硬编码加密密匙会大大降低系统安全性。 对于避免使用硬编码密匙的情况&#xff0c;示例1给出了不…

jQUery(基本介绍+示例代码)

一、JQUery基本介绍和特点 jQuery 是一个快速、轻量级、跨浏览器的 JavaScript 库。它简化了在网页开发中处理诸多任务的过程&#xff0c;提供了易于使用的 API&#xff0c;使得开发者能够更容易地操作 HTML 文档、处理事件、执行动画、发送 AJAX 请求等。 以下是一些 jQuery…

CTF/AWD竞赛标准参考书+实战指南

随着网络安全问题日益凸显&#xff0c;国家对网络安全人才的需求持续增长&#xff0c;其中&#xff0c;网络安全竞赛在国家以及企业的人才培养和选拔中扮演着至关重要的角色。 在数字化时代&#xff0c;企业为了应对日益增长的攻击威胁&#xff0c;一般都在大量部署安全产品、…

PyInstaller 如何 将第三方库打包到可执行文件

PyInstaller 是一个非常流行的 Python 打包工具&#xff0c;它可以将你的 Python 程序以及其依赖项打包成一个可执行文件。如果你想将第三方库打包到可执行文件中&#xff0c;你可以按照以下步骤操作&#xff1a; 首先&#xff0c;确保你已经安装了 PyInstaller。如果没有&…

uview-plus u-picker的defaultIndexs修改后无效的问题

uniapp项目中使用了uview-plus组件库&#xff0c;在使用u-picker组件时&#xff0c;发现其默认的选中属性 defaultIndex是一次性的&#xff0c;修改后无法响应&#xff0c;解决办法就是在u-picker源码中修改这个属性的watch,源码位置在uni_modules/uview-plus/components/u-pi…

Hive 定义变量 变量赋值 引用变量

Hive 定义变量 变量赋值 引用变量 变量 hive 中变量和属性命名空间 命名空间权限描述hivevar读写用户自定义变量hiveconf读写hive相关配置属性system读写java定义额配置属性env只读shell环境定义的环境变量 语法 Java对这个除env命名空间内容具有可读可写权利&#xff1b; …

Qt如何解析JSON格式

Qt 5.15 版本以后&#xff0c;推荐使用 QJsonDocument 来解析 JSON 数据。 直接贴代码&#xff1a; #include <QJsonDocument> #include <QJsonObject> #include <QFile>// 从文件中读取 JSON 数据 QFile file("data.json"); file.open(QIODevi…

SQL零基础入门教程,贼拉详细!贼拉简单! 速通数据库期末考!(十一)

COUNT() 计数函数 COUNT() 函数返回匹配指定条件的行数。 语法&#xff1a; 1.返回指定列的字段值条数 SELECT COUNT(column_name) FROM table_name;2.返回整表数据行条数 SELECT COUNT(*) FROM table_name;3.返回指定列去重后的字段值条数 SELECT COUNT(DISTINCT column_…

Leetcode 第 372 场周赛题解

Leetcode 第 372 场周赛题解 Leetcode 第 372 场周赛题解题目1&#xff1a;2937. 使三个字符串相等思路代码复杂度分析 题目2&#xff1a;2938. 区分黑球与白球思路代码复杂度分析 题目3&#xff1a;2939. 最大异或乘积思路代码复杂度分析 题目4&#xff1a;2940. 找到 Alice 和…