C++筛选法实现2~200范围素数查找
需积分: 10 163 浏览量
更新于2024-08-23
收藏 8.66MB PPT 举报
在C++程序设计中,谭浩强编著的教材中介绍了一种求解素数的方法,即筛法。这种算法用于寻找2到200之间的所有素数。筛法的基本原理是利用数组来存储从1到指定范围的数,初始时所有数都被标记为素数(非零)。然后从最小的素数2开始,将其倍数标记为合数(非素数),接着移动到下一个未被标记的数3,重复这个过程,直到遍历到当前范围内的最大素数。在这个例子中,数组的初始状态如下:
```
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
2 3 0 5 0 7 0 9 0 11 0 13 0 15 0 17 0 19 0
2 3 0 5 0 7 0 0 0 11 0 13 0 0 0 17 0 19 0
```
步骤如下:
1. 首先,创建一个数组,长度为要查找范围的上限(这里是200),并将所有元素初始化为1(因为默认情况下所有数被视为素数)。
2. 从2开始,如果数组中的当前元素是素数(值为1),则输出该数。然后,将该数的所有倍数(2的倍数、4的倍数等)的数组元素设置为0,表示它们不是素数。
3. 继续检查下一个未被标记为0的数,重复上述过程,直到遍历完数组。
C++实现此算法的关键在于循环和条件判断。例如,以下是一个简化版的C++代码片段:
```cpp
#include <iostream>
#include <vector>
bool isPrime(int num) {
if (num <= 1) return false;
for (int i = 2; i * i <= num; i++) {
if (num % i == 0) return false;
}
return true;
}
void sieveOfEratosthenes(int n) {
std::vector<bool> primes(n + 1, true);
primes[0] = primes[1] = false;
for (int i = 2; i * i <= n; i++) {
if (primes[i]) {
for (int j = i * i; j <= n; j += i) {
primes[j] = false;
}
}
}
for (int i = 2; i <= n; i++) {
if (primes[i]) {
std::cout << i << " ";
}
}
}
int main() {
sieveOfEratosthenes(200);
return 0;
}
```
这段代码首先定义了一个`isPrime`函数来检查单个数是否为素数,然后在`sieveOfEratosthenes`函数中实现了筛法。最后,在`main`函数中调用该函数找出2到200之间的所有素数并打印出来。
C++语言在程序设计中的特点,如结构化、灵活性高、与低级语言结合以及良好的可移植性,使得它非常适合实现此类算法。然而,由于C++语法相对复杂,对于初学者来说可能需要一定时间去熟悉和掌握。尽管调试过程中可能存在挑战,但只要理解了C++的语法规则,编写和调试程序是可以逐步掌握的。
2020-04-24 上传
2012-10-09 上传
2010-01-12 上传
2024-10-26 上传
2023-05-30 上传
2024-11-05 上传
2023-08-13 上传
2023-04-26 上传
2023-11-13 上传
xxxibb
- 粉丝: 20
- 资源: 2万+
最新资源
- MATLAB实现小波阈值去噪:Visushrink硬软算法对比
- 易语言实现画板图像缩放功能教程
- 大模型推荐系统: 优化算法与模型压缩技术
- Stancy: 静态文件驱动的简单RESTful API与前端框架集成
- 掌握Java全文搜索:深入Apache Lucene开源系统
- 19计应19田超的Python7-1试题整理
- 易语言实现多线程网络时间同步源码解析
- 人工智能大模型学习与实践指南
- 掌握Markdown:从基础到高级技巧解析
- JS-PizzaStore: JS应用程序模拟披萨递送服务
- CAMV开源XML编辑器:编辑、验证、设计及架构工具集
- 医学免疫学情景化自动生成考题系统
- 易语言实现多语言界面编程教程
- MATLAB实现16种回归算法在数据挖掘中的应用
- ***内容构建指南:深入HTML与LaTeX
- Python实现维基百科“历史上的今天”数据抓取教程