AcWing算法基础课笔记——质数

质数

质数:在大于1的整数中,如果只包含1和它本身这两个约数,就被称之为质数

(1)质数的判定——试除法

bool is_prime(int n) {if (n < 2) return false;for(int i = 2; i <= n / i; i ++ ) {if(n % i == 0) return false;}return true;
}

时间复杂度O(sqrt(n)) 一定是sqrt(n)

(2)分解质因数——试除法

从小到大枚举所有数

n中最多只包含一个大于sqrt(n)的质因子,因此可以单独把质因子拿出来,这样就可以把时间复杂度降低到sqrt(n) (一般logn ~ sqrt(n))

void divide(int x) {for(int i = 2; i <= n / i; i ++ ) {if(n % i == 0) {int s = 0;while(n % i == 0) {n /= i;s ++;}printf("%d %d \n", i, s);}}if(n > 1) printf("%d %d\n", n, 1);puts("");
}

(3)筛质数

a. 埃式筛法

时间复杂度O(nloglogn)

void 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;}}
}
b. 线性筛法

保证每个数只会被它的最小质因子筛掉

void 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;if(i % primes[j] == 0) break; //primes[j]是i的最小质因子}}
}

当n = 1e6,线性筛法和埃式筛法时间差不多,当n = 1e7,线性筛法更快

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

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

相关文章

API低代码平台介绍6-数据库记录删除功能

数据库记录删除功能 在前续文章中我们介绍了如何插入和修改数据库记录&#xff0c;本篇文章会沿用之前的测试数据&#xff0c;介绍如何使用ADI平台定义一个删除目标数据库记录的接口&#xff0c;包括 单主键单表删除、复合主键单表删除、多表删除&#xff08;整合前两者&#x…

JS 【详解】树的遍历(含深度优先遍历和广度优先遍历的算法实现)

用 js 描述树 let tree [{label:a,children:[{label:b,children:[{label:d},{label:e}]},{label:c,children:[{label:f}]}]} ]使用数组是因为树的节点有顺序 深度优先遍历 从根节点出发&#xff0c;优先遍历最深的节点 遍历顺序为 abdecf function DFS(tree) {tree.forEach(…

揭示SOCKS5代理服务器列表的重要性

在复杂的网络安全领域中&#xff0c;SOCKS5代理在保护在线活动方面发挥着关键作用。本文深入探讨了SOCKS5代理服务器列表的细节&#xff0c;探讨了它们的应用、优势以及在增强在线安全和隐私方面不可或缺的功能。 一、理解SOCKS5代理服务器列表 作为在客户端和服务器之间进行通…

QListWidget、QMenu、Action、customContextMenuRequested

QListWidget的初始化、清空、Append添加、Insert添加、删除item QListWidget的事件的使用 QToolBox的使用&#xff0c;每个Page可以添加其他控件 QToolBar使用代码添加QMenu,QMenu添加3个Action QToolButton绑定Action 布局 其中 QSplitter比较特殊&#xff0c; 允许在水平或垂…

实现锚点链接点击tab跳转到指定位置 并且滚动鼠标顶部锚点的样式也跟随变化

实现效果如下 不管是点击还是 滚动鼠标 顶部的样式也会跟随变化 点击会跳转到指定的位置 通过IntersectionObserver 监听是否可见 下面代码可以直接执行到vue的文件 <template><div><ul class"nav"><li v-for"tab in tabs" :key…

【MYSQL】解决数据库Too many connections

Linux登录mysql mysql -u root -p 查看 mysql 服务器中的活动进程数量 mysql> select count(*) from information_schema.processlist;---------- | count(*) | ---------- | 296 | ---------- 1 row in set (0.00 sec)查看 mysql 数据库中当前活动连接的客户端 IP 地址…

Nvidia Isaac Sim组装机器人和添加传感器 入门教程 2024(5)

Nvidia Isaac Sim 入门教程 2024 版权信息 Copyright 2023-2024 Herman YeAuromix. All rights reserved.This course and all of its associated content, including but not limited to text, images, videos, and any other materials, are protected by copyright law. …

采购管理系统:反向竞价失败的 6 个常见原因

在当今快节奏和竞争激烈的商业环境中&#xff0c;采购专业人员一直在寻找创新战略来节约成本和简化供应链流程。反向竞价就是其中一种广受欢迎的策略。 反向竞价提供了一种独特的采购方法&#xff0c;允许买家邀请多个供应商参与实时竞标&#xff0c;以争取他们的业务。虽然反…

[Linux内核驱动]模块的加载和卸载

Linux内核模块的加载和卸载 最简单的内核模块&#xff0c;包括内核模块的加载和卸载。 更多详细内容可以查看我的github 运行 make // 加载 insmod hello.ko // 卸载 rmmod hello模块加载函数 Linux内核模块加载函数一般以 __init 标识声明&#xff0c;然后用 module_init(函…

构建个人文件上传服务:Python Flask实现上传和下载完整指南

介绍 在本教程中&#xff0c;我们将学习如何使用Python Flask框架将文件上传到服务器&#xff0c;并使用SQLite数据库来跟踪上传的文件。我们将提供后端代码和一个示例项目的Git链接&#xff0c;以便您可以轻松地跟随本教程。 准备工作 首先&#xff0c;您需要安装Python和F…

太爱这种数据可视化效果,零售行业的都看过来

在当今数字化浪潮下&#xff0c;数据可视化已成为零售行业洞察市场趋势、优化运营决策的关键技术。奥威BI零售数据分析方案凭借其卓越的数据可视化效果&#xff0c;成为零售企业的得力助手。接下来就通过BI节假日分析报表来简单地感受一下。 注&#xff1a;该BI节假日分析报表…

网络安全突发事件应急预案

1.总则 1.1 编制目的 建立健全网络安全突发事件应急组织体系和工作机制&#xff0c;提高网络安全突发事件综合应对能力&#xff0c;确保及时有效地控制、减轻和消除网络安全突发事件造成的社会危害和损失&#xff0c;保证持续稳定运行和数据安全。 1.2 编制依据 …

新版本vue-cli打包之后没有css文件

新版本vue-cli打包之后没有css文件 vueCli配置文档 将css.extract 设置为 true就可以了 module.exports {css: {extract: true} }

chromadb

https://www.trychroma.com/ https://docs.trychroma.com/getting-started chroma 向量数据库使用教程 ChromaDB python 使用教程及记录 向量数据库检索原理 向量数据库FAISS/Chromadb/ES/milvus简单概述

adb指令切换cpu工作状态至性能模式

adb 指令 adb root adb wait-for-device adb remount adb wait-for-device adb shell "setprop persist.sys.enable.hypnus 0" adb shell "rmmod hypnus" adb shell "cat /sys/devices/system/cpu/cpu*/online" adb shell stop mpdecision adb …

oracle-定时器(job)

--1分钟运行一次定时任务。sysdate为了定时任务即可生效。 DECLARE JOB NUMBER; BEGIN DBMS_JOB.SUBMIT(JOB,P_HJZ_HJZ_PJ_DDYTKAPB_INIT_JOB;,SYSDATE,sysdate1/24/60); COMMIT; END; / select * from user_jobs; --删除 begin DBMS_JOB.broken (462, false); DBM…

java读取大文件报错

报错如下&#xff1a; java.io.IOException: Zip bomb detected! The file would exceed the max. ratio of compressed file size to the size of the expanded data. This may indicate that the file is used to inflate memory usage and thus could pose a security risk…

DDMA信号处理以及数据处理的流程---cfar检测

Hello,大家好,我是Xiaojie,好久不见,欢迎大家能够和Xiaojie一起学习毫米波雷达知识,Xiaojie准备连载一个系列的文章—DDMA信号处理以及数据处理的流程,本系列文章将从目标生成、信号仿真、测距、测速、cfar检测、测角、目标聚类、目标跟踪这几个模块逐步介绍,这个系列的…

Nacos安装教程(很细很简单),解决启动报错Please set the JAVA_HOME

nacos安装 找到你要下载的版本解压到任意非中文目录下端口默认8848&#xff0c;如有端口冲突&#xff0c;可修改配置文件中的端口。编辑shutdown.cmd文件&#xff0c;路径换成你的jdk安装地址否则会报错Please set the JAVA_HOME variable in your environment, We need java(x…

安卓应用开发——Android Studio中通过id进行约束布局

在Android开发中&#xff0c;布局通常使用XML文件来描述&#xff0c;而约束&#xff08;如相对位置、大小等&#xff09;可以通过多种方式实现&#xff0c;但直接使用ID进行约束并不直接对应于Android的传统布局系统&#xff08;如LinearLayout、RelativeLayout等&#xff09;。…