C++筛选法实现2~200范围素数查找
需积分: 10 107 浏览量
更新于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 上传
点击了解资源详情
点击了解资源详情
点击了解资源详情
点击了解资源详情
点击了解资源详情
点击了解资源详情
xxxibb
- 粉丝: 22
- 资源: 2万+
最新资源
- 收集的vc button 按钮源代码,仿iphone界面
- 易语言标签批量打印源码.zip
- GIMworld一键集运插件-crx插件
- react-webpack-boilerplate
- adb命令读/写操作: 可以嵌入到代码中执行
- rest-delphi:API分离和Delphi XE10 usando框架马
- 宁德新能源科技-电子签章.zip
- 跨时钟域问题解决方法.rar
- LeetCode:解决LeetCode的问题
- 基于大语言模型的交互式视频检索引擎,使用python+Django框架实现的
- HSTimestamp:这是一个库。 关于时间戳。 您可以使用它来获取当前时间戳,并获得有关time-ago的功能。
- 通用adb调试工具下载
- CS1699-Deliverable3:皮特 CS 1699 - 可交付成果 #3
- VC++动态设置窗体内文字的颜色
- AGBooks:教科书分发解决方案
- libqtcp:通过网络提供通信的库-开源