C++ 中的质数生成器
本篇文章指导使用简单、直观的方法和高效的平方根方法生成给定范围内的所有质数。
质数
质数是可以被一整除或只能被其自身整除的数; 例如,17 是一个只能被 1 或它本身整除的数字。 质数 P 的唯一可能因子是 P * 1。
让我们看一下质数集:
Set of Prime Numbers = {2, 3, 5 , 7, 11, 13, 17, 23, .....,89, 97, .... }
在C++中,我们可以编写这样的场景,生成某个范围内的质数,甚至可以判断一个数是否为质数。
在 C++ 中生成质数
检查一个数是否为质数背后的逻辑是检查其模数,所有数最多为该数的一半。 如果它与任何数的模数为 0,则该数不是质数; 否则,它是质数。
让我们看看最简单、最直观的方法:
#include <iostream>
using namespace std;
int main() {
int start = 0, end = 100, n;
bool ifPrime = true;
cout << "Prime numbers in between " << start << " and " << end << " are the following: " << endl;
while (start < end) {
ifPrime = true;
if (start == 0 || start == 1) {
ifPrime = false;
}
for (n = 2; n <= start/2; ++n) {
if (start % n == 0) {
ifPrime = false;
break;
}
}
if (ifPrime)
cout << start << ", ";
++start;
}
return 0;
}
我们在上面的代码段中取了两个变量,start 和 end。 起始变量初始化为零,结束变量初始化为 100,因为我们需要从 0 到 100 的质数。
该范围可以随时更改,也可以作为用户的输入。
我们从头到尾创建了一个循环; 在那个循环中,我们做了另一个 for 循环来检查起始数字是否可以被数字的一半整除。 这是因为,对于一个非质数N,只能存在数为a和b的因数使得a*b,其中a<N/2且b<N/2。
因此,如果内部 for 循环让 n 接近起始值的一半,则循环终止,并且数字在第 25 行打印出来,因为 ifprime 仍然为真。 但是,如果 n 的任何值都能正确地除以起始值,则第 19 行的条件变为真,将 ifprime 设置为假并终止 for 循环。
输出:
在 C++ 中使用 sqrt() 方法生成质数
前面讨论的简单质数计算方法效率低下,因为它仍然需要我们除以数字的一半来检查它是否是质数。 但是,我们可以利用数学事实来降低程序运行时间的复杂性。
该程序从以下事实中得到帮助:对于等于数字 N 的因子 a*b
,a 或 b 必须小于或等于 N 的平方根。例如,对于 36,可能的因子对是 (9*4), (18*2), (12*3), (6*6),所以每一对的a或b都小于36的平方根。
因此,要否定一个数 N 不是质数,我们只需要检查它是否可以被任何小于 N 的平方根的数整除。 如果不是,则表示该数是质数。
现在,让我们编写场景代码:
#include <iostream>
#include <math.h>
using namespace std;
int main() {
int start = 0, end = 100, n;
bool ifPrime = true;
cout << "Prime numbers in between " << start << " and " << end << " are the following: " << endl;
while (start < end) {
ifPrime = true;
if (start == 0 || start == 1) {
ifPrime = false;
}
for (n = 2; n <= sqrt(start); ++n) {
if (start % n == 0) {
ifPrime = false;
break;
}
}
if (ifPrime)
cout << start << ", ";
++start;
}
return 0;
}
我们已经创建了一个从头到尾的循环,在该循环中,我们将对数字求平方根,这将是内循环的截断数。
内部循环将检查当前数字是否可以被任何数字整除直到其平方根。 如果不是,我们将其打印为质数。
输出结果:
相关文章
在 C++ 中通过掷骰子生成随机值
发布时间:2023/04/09 浏览次数:169 分类:C++
-
本文解释了如何使用时间因子方法和模拟 C++ 中的掷骰子的任意数方法生成随机数。了解它是如何工作的以及它包含哪些缺点。提供了一个 C++ 程序来演示伪数生成器。
在 C++ 中使用模板的链表
发布时间:2023/04/09 浏览次数:158 分类:C++
-
本文解释了使用模板在 C++ 中创建链表所涉及的各个步骤。工作程序演示了一个链表,该链表使用模板来避免在创建新变量时声明数据类型的需要。
在 C++ 中添加定时延迟
发布时间:2023/04/09 浏览次数:142 分类:C++
-
本教程将为你提供有关在 C++ 程序中添加定时延迟的简要指南。这可以使用 C++ 库为我们提供的一些函数以多种方式完成。
在 C++ 中创建查找表
发布时间:2023/04/09 浏览次数:155 分类:C++
-
本文重点介绍如何创建查找表及其在不同场景中的用途。提供了三个代码示例以使理解更容易,并附有代码片段以详细了解代码。
如何在 C++ 中把字符串转换为小写
发布时间:2023/04/09 浏览次数:63 分类:C++
-
介绍了如何将 C++ std::string 转换为小写的方法。当我们在考虑 C++ 中的字符串转换方法时,首先要问自己的是我的输入字符串有什么样的编码
如何在 C++ 中确定一个字符串是否是数字
发布时间:2023/04/09 浏览次数:163 分类:C++
-
本文介绍了如何检查给定的 C++ 字符串是否是数字。在我们深入研究之前,需要注意的是,以下方法只与单字节字符串和十进制整数兼容。
如何在 c++ 中查找字符串中的子字符串
发布时间:2023/04/09 浏览次数:65 分类:C++
-
本文介绍了在 C++ 中检查一个字符串是否包含子字符串的多种方法。使用 find 方法在 C++ 中查找字符串中的子字符串
如何在 C++ 中把字符串转换为 Char 数组
发布时间:2023/04/09 浏览次数:107 分类:C++
-
本文介绍了在 C++ 中把字符串转换为 char 数组的多种方法。使用 std::basic_string::c_str 方法将字符串转换为 char 数组