c 中的质数生成器-ag捕鱼王app官网

c 中的质数生成器

作者:迹忆客 最近更新:2023/03/31 浏览次数:

本篇文章指导使用简单、直观的方法和高效的平方根方法生成给定范围内的所有质数。

质数

质数是可以被一整除或只能被其自身整除的数; 例如,17 是一个只能被 1 或它本身整除的数字。 质数 p 的唯一可能因子是 p * 1。

让我们看一下质数集:

set of prime numbers = {2, 3, 5 , 7, 11, 13, 17, 23, .....,89, 97, .... }

在c 中,我们可以编写这样的场景,生成某个范围内的质数,甚至可以判断一个数是否为质数。


在 c 中生成质数

检查一个数是否为质数背后的逻辑是检查其模数,所有数最多为该数的一半。 如果它与任何数的模数为 0,则该数不是质数; 否则,它是质数。

让我们看看最简单、最直观的方法:

#include 
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;
}

我们在上面的代码段中取了两个变量,startend。 起始变量初始化为零,结束变量初始化为 100,因为我们需要从 0 到 100 的质数。

该范围可以随时更改,也可以作为用户的输入。

我们从头到尾创建了一个循环; 在那个循环中,我们做了另一个 for 循环来检查起始数字是否可以被数字的一半整除。 这是因为,对于一个非质数n,只能存在数为a和b的因数使得a*b,其中a

因此,如果内部 for 循环让 n 接近起始值的一半,则循环终止,并且数字在第 25 行打印出来,因为 ifprime 仍然为真。 但是,如果 n 的任何值都能正确地除以起始值,则第 19 行的条件变为真,将 ifprime 设置为假并终止 for 循环。

输出:

c   prime numbers output 1


在 c 中使用 sqrt() 方法生成质数

前面讨论的简单质数计算方法效率低下,因为它仍然需要我们除以数字的一半来检查它是否是质数。 但是,我们可以利用数学事实来降低程序运行时间的复杂性。

该程序从以下事实中得到帮助:对于等于数字 n 的因子 a*b ,a 或 b 必须小于或等于 n 的平方根。例如,对于 36,可能的因子对是 (9*4), (18*2), (12*3), (6*6),所以每一对的a或b都小于36的平方根。

因此,要否定一个数 n 不是质数,我们只需要检查它是否可以被任何小于 n 的平方根的数整除。 如果不是,则表示该数是质数。

现在,让我们编写场景代码:

#include 
#include 
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   prime numbers output 2

上一篇:

下一篇:在 c 中计算平均值

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

arduino 中停止循环

发布时间:2024/03/13 浏览次数:444 分类:c

可以使用 exit(0),无限循环和 sleep_n0m1 库在 arduino 中停止循环。

arduino 复位

发布时间:2024/03/13 浏览次数:315 分类:c

可以通过使用复位按钮,softwarereset 库和 adafruit sleepydog 库来复位 arduino。

发布时间:2024/03/13 浏览次数:181 分类:c

可以使用简单的方法 toint()函数和 serial.parseint()函数将 char 转换为 int。

arduino 串口打印多个变量

发布时间:2024/03/13 浏览次数:381 分类:c

可以使用 serial.print()和 serial.println()函数在串口监视器上显示变量值。

arduino if 语句

发布时间:2024/03/13 浏览次数:123 分类:c

可以使用 if 语句检查 arduino 中的不同条件。

arduino icsp

发布时间:2024/03/13 浏览次数:214 分类:c

icsp 引脚用于两个 arduino 之间的通信以及对 arduino 引导加载程序进行编程。

发布时间:2024/03/13 浏览次数:151 分类:c

可以使用 arduino 中的循环制作计数器。

使用 c 编程 arduino

发布时间:2024/03/13 浏览次数:127 分类:c

本教程将讨论使用 arduino ide 在 c 中对 arduino 进行编程。

arduino 中的子程序

发布时间:2024/03/13 浏览次数:168 分类:c

可以通过在 arduino 中声明函数来处理子程序。

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便
网站地图