埃氏算法C++实现: 快速输出质数( 素数 )

目录

1.简介

算法原理

算法特点

应用场景

2.一般求素数方法

3.埃氏算法求素数

3.1.无动态分配

3.2.有动态分配


1.简介

埃氏算法(Eratosthenes Sieve)‌,全称为埃拉托斯特尼筛法,是一种由古希腊数学家埃拉托斯特尼在公元前3世纪提出的古老而经典的算法,用于计算一定范围内的素数。其基本思想是通过从小到大遍历每个数字,并将其所有倍数标记为非质数,从而逐步排除所有非质数,最终得到所有的素数。‌

算法原理

埃氏筛法的基本原理是:要得到自然数n以内的全部素数,必须把不大于√n的所有素数的倍数剔除,剩下的就是素数。具体步骤如下:

  1. 初始化:创建一个布尔类型的数组(或列表),用于表示范围内的所有数字,初始时将所有元素标记为“true”,表示都是素数(或待检定的数)。
  2. 遍历与筛选:从2开始遍历数组中的每个数。如果当前数字被标记为素数(即为“true”),则进行下一步筛选操作;否则,跳过该数字。对于当前素数p,从p的平方开始,将p的倍数(如2p、3p、4p等)标记为非质数(即为“false”),因为p的所有小于p平方的倍数在之前的步骤中已经被更小的素数筛选过了。
  3. 重复操作:继续向后遍历,重复步骤2的筛选过程,直到遍历完整个范围。
  4. 输出结果:遍历结束后,所有未被标记为非质数(仍为“true”)的数字都是素数,将其输出即可。

算法特点

  1. 简单直观‌:埃氏筛法的原理简单易懂,实现起来也较为直接。
  2. 高效性‌:虽然算法的时间复杂度为O(nloglogn),但在实际应用中,它仍然是寻找一定范围内素数的高效方法之一。
  3. 历史悠久‌:作为一种古老的算法,埃氏筛法在数学史上占有重要地位,是素数研究的基础工具之一。

应用场景

埃氏筛法广泛应用于数论、密码学、计算机科学等领域,特别是在需要快速生成大量素数时,其高效性得到了充分体现。例如,在密码学中的RSA算法中,就需要生成大量的素数作为密钥的基础。

2.一般求素数方法

#include <iostream>
#include <cmath>using namespace std;bool is_prime(int num) {if (num <= 1) return false;if (num == 2) return true; // 2 is the only even prime numberif (num % 2 == 0) return false; // other even numbers are not primesint sqrt_num = static_cast<int>(sqrt(num));for (int i = 3; i <= sqrt_num; i += 2) {if (num % i == 0) return false;}return true;
}void find_primes_up_to(int n, int* primes, int& prime_count) {prime_count = 0;for (int i = 2; i <= n; ++i) {if (is_prime(i)) {primes[prime_count++] = i;}}
}int main() {int n;cout << "Enter a number: ";cin >> n;// Assuming the maximum number of primes is n/2 (an overestimate)int* primes = new int[n / 2];int prime_count;find_primes_up_to(n, primes, prime_count);cout << "Prime numbers up to " << n << " are: ";for (int i = 0; i < prime_count; ++i) {cout << primes[i] << " ";}cout << endl;delete[] primes; // Free the allocated memoryreturn 0;
}

3.埃氏算法求素数

3.1.无动态分配

#include <iostream>
#include <cmath>using namespace std;bool is_prime(int num) {if (num <= 1) return false;if (num == 2) return true; // 2 is the only even prime numberif (num % 2 == 0) return false; // other even numbers are not primesint sqrt_num = static_cast<int>(sqrt(num));for (int i = 3; i <= sqrt_num; i += 2) {if (num % i == 0) return false;}return true;
}void find_primes_up_to(int n, int primes[], int& prime_count) {prime_count = 0;for (int i = 2; i <= n; ++i) {if (is_prime(i)) {primes[prime_count++] = i;}}
}int main() {int n;cout << "Enter a number: ";cin >> n;// Assuming the maximum number of primes is n/2 (an overestimate)int primes[n / 2];int prime_count;find_primes_up_to(n, primes, prime_count);cout << "Prime numbers up to " << n << " are: ";for (int i = 0; i < prime_count; ++i) {cout << primes[i] << " ";}cout << endl;return 0;
}

3.2.有动态分配

#include <iostream>
#include <cmath>using namespace std;bool is_prime(int num) {if (num <= 1) return false;if (num == 2) return true; // 2 is the only even prime numberif (num % 2 == 0) return false; // other even numbers are not primesint sqrt_num = static_cast<int>(sqrt(num));for (int i = 3; i <= sqrt_num; i += 2) {if (num % i == 0) return false;}return true;
}void find_primes_up_to(int n, int* primes, int& prime_count) {prime_count = 0;for (int i = 2; i <= n; ++i) {if (is_prime(i)) {primes[prime_count++] = i;}}
}int main() {int n;cout << "Enter a number: ";cin >> n;// Assuming the maximum number of primes is n/2 (an overestimate)int* primes = new int[n / 2];int prime_count;find_primes_up_to(n, primes, prime_count);cout << "Prime numbers up to " << n << " are: ";for (int i = 0; i < prime_count; ++i) {cout << primes[i] << " ";}cout << endl;delete[] primes; // Free the allocated memoryreturn 0;
}

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

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

相关文章

【机器学习】嘿马机器学习(科学计算库)第11篇:Pandas,学习目标【附代码文档】

本教程的知识点为&#xff1a;机器学习&#xff08;常用科学计算库的使用&#xff09;基础定位 机器学习概述 机器学习概述 1.5 机器学习算法分类 1 监督学习 机器学习概述 1.7 Azure机器学习模型搭建实验 Azure平台简介 Matplotlib 3.2 基础绘图功能 — 以折线图为例 1 完善原…

FFPlay命令全集合

FFPlay是以FFmpeg框架为基础&#xff0c;外加渲染音视频的库libSDL构建的媒体文件播放器。 ffplay工具下载并播放视频&#xff0c;可以辅助卡看流信息。 官网下载地址&#xff1a;http://ffmpeg.org/download.html#build-windows 下载build好的exe程序&#xff1a; 此处下载…

DNS未响应服务问题的解决(电脑连着网但浏览器访问不了网页)

天行健&#xff0c;君子以自强不息&#xff1b;地势坤&#xff0c;君子以厚德载物。 每个人都有惰性&#xff0c;但不断学习是好好生活的根本&#xff0c;共勉&#xff01; 文章均为学习整理笔记&#xff0c;分享记录为主&#xff0c;如有错误请指正&#xff0c;共同学习进步。…

vue视频流播放,支持多种视频格式,如rmvb、mkv

先将视频转码为ts ffmpeg -i C:\test\3.rmvb -codec: copy -start_number 0 -hls_time 10 -hls_list_size 0 -f hls C:\test\a\output.m3u8 后端配置接口 import org.springframework.core.io.Resource; import org.springframework.core.io.UrlResource; import org.spring…

从 0 开始实现一个 SpringBoot + Vue 项目

从 0 开始实现一个 SpringBoot Vue 项目 从 0 开始实现一个 SpringBoot Vue 项目 软件和工具创建 SpringBoot 后端项目创建 MySQL 数据库配置文件实现增删改查接口 Model 层mapper 层service 层controller 层测试 实现项目功能接口 代码测试 创建 Vue 前端 安装 Node.js配置…

每日一题洛谷P1423 小玉在游泳c++

#include<iostream> using namespace std; int main() {double s;cin >> s;int n 0;double sum 0;double k 2;while (sum < s) {sum k;n;k * 0.98;}cout << n << endl;return 0; }

flutter跨端UI框架简介

flutter跨端UI框架简介 简介 Flutter是由Google开发的开源应用开发框架&#xff0c;主要用于构建高性能、跨平台的移动、Web和桌面应用程序。Flutter使用Dart语言&#xff0c;提供了一套丰富的Widgets&#xff0c;使开发者能够快速创建美观的用户界面。其最大特点是热重载功能…

java提取系统应用的日志中的sql获取表之间的关系

为了获取到对应的sql数据&#xff0c;分了三步骤 第一步&#xff0c;获取日志文件&#xff0c;解析日志文件中的查询sql&#xff0c;递归解析sql&#xff0c;获取表关系集合 递归解析sql&#xff0c;获取表与表之间的关系 输出得到的对应关联关系数据 第二步&#xff0c;根据获…

16_动态提示窗口_协程延时

创建动态提示窗口DynamicWnd.cs 编写代码 using UnityEngine; using UnityEngine.UI; //功能 : 动态窗口界面 public class DynamicWnd : WindowsRoot{public Animation tipsAni;public Text txtTips;protected override void InitWnd() {base.InitWnd();//在启动时先隐藏提示…

路由器旁挂三层网络实现SDWAN互联(爱快SD-WAN)

近期因公司新办公区建设&#xff0c;原有的爱快路由器的SDWAN功能实现分支之间互联的服务还需要继续使用。在原有的小型网络中&#xff0c;使用的爱快路由器当作网关设备&#xff0c;所以使用较为简单,如下图所示。 现变更网络拓扑为三层网络架构&#xff0c;但原有的SDWAN分支…

隐私保护+性能优化,RyTuneX 让你的电脑更快更安全

RyTuneX 是一款专为 Windows 10 和 11 用户量身打造的系统优化工具&#xff0c;采用先进的 WinUI 3 框架开发&#xff0c;以其现代化的设计风格和强大的功能集合脱颖而出。这款工具不仅界面简洁美观&#xff0c;还提供了多样化的系统优化选项&#xff0c;旨在帮助用户最大化设备…

java上传图片功能实现

1 MinIO核心概念 下面介绍MinIO中的几个核心概念&#xff0c;这些概念在所有的对象存储服务中也都是通用的。 对象&#xff08;Object&#xff09; 对象是实际的数据单元&#xff0c;例如我们上传的一个图片。 存储桶&#xff08;Bucket&#xff09; 存储桶是用于组织对象的命…

深入MapReduce——引入

引入 前面我们已经深入了HDFS的设计与实现&#xff0c;对于分布式系统也有了不错的理解。 但HDFS仅仅解决了海量数据存储和读写的问题。要想让数据产生价值&#xff0c;一定是需要从数据中挖掘出价值才行&#xff0c;这就需要我们拥有海量数据的计算处理能力。 下面我们还是…

解决npm install安装出现packages are looking for funding run `npm fund` for details问题

当我们运行npm install时&#xff0c;可能会收到类似以下的提示信息&#xff1a;“x packages are looking for funding.” 这并不是错误提示&#xff0c;也不会影响项目的正常运行。其实实在提醒有一些软件包正在寻求资金支持。 根据提示输入npm fund可以查看详细的信息&#…

小米Vela操作系统开源:AIoT时代的全新引擎

小米近日正式开源了其物联网嵌入式软件平台——Vela操作系统&#xff0c;并将其命名为OpenVela。这一举动在AIoT&#xff08;人工智能物联网&#xff09;领域掀起了不小的波澜&#xff0c;也为开发者们提供了一个强大的AI代码生成器和开发平台。OpenVela项目源代码已托管至GitH…

2025_1_22打卡

402. 移掉 K 位数字 - 力扣&#xff08;LeetCode&#xff09; 279. 完全平方数 - 力扣&#xff08;LeetCode&#xff09;

【搞机】GMK-G3因特尔n100处理器核显直通win10虚拟机

环境 系统&#xff1a;Proxmox Virtual Environment 8.1.3 Linux内核&#xff1a;Linux version 6.5.13-6-pve (buildproxmox) (gcc (Debian 12.2.0-14) 12.2.0, GNU ld (GNU Binutils for Debian) 2.40) #1 SMP PREEMPT_DYNAMIC PMX 6.5.13-6 (2024-07-26T12:34Z) CPU&#x…

MECD+: 视频推理中事件级因果图推理--VLM长视频因果推理

论文链接&#xff1a;https://arxiv.org/pdf/2501.07227v1 1. 摘要及主要贡献点 摘要&#xff1a; 视频因果推理旨在从因果角度对视频内容进行高层次的理解。然而&#xff0c;目前的研究存在局限性&#xff0c;主要表现为以问答范式执行&#xff0c;关注包含孤立事件和基本因…

2024“博客之星”——我的博客成长与技术洞察

&#x1f31f;欢迎来到 我的博客 —— 探索技术的无限可能&#xff01; &#x1f31f;博客的简介&#xff08;文章目录&#xff09; 目录 一、引言二、个人成长与突破盘点&#xff08;一&#xff09;技能提升与知识拓展&#xff08;二&#xff09;创作风格与影响力提升&#xf…

KOC营销2.0:出海品牌在2025年春节的创新故事讲述

在全球化日益加深的今天&#xff0c;春节已不再是中国独有的节日符号&#xff0c;它逐渐成为了世界各地文化交融的一部分。对于出海品牌而言&#xff0c;春节不仅是连接中国消费者与海外市场的桥梁&#xff0c;更是展示品牌文化深度与创意的重要契机。KOC营销作为新时代的传播策…