返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C++两种素数判定方法
  • 341
分享到

C++两种素数判定方法

C++素数判定C++素数 2022-11-13 14:11:03 341人浏览 独家记忆
摘要

目录1.什么是素数2.素数的两种判断方法(1)暴力法从 2 到 √n6n-1与6n+1(2)筛法埃氏筛欧拉筛1.什么是素数 素数又称质数。一个大于1的自然数,除了1和它自

1.什么是素数

素数又称质数。一个大于1的自然数,除了1和它自身外,不能被其他自然数整除的数叫做素数;否则称为合数(规定1既不是素数也不是合数)。

在许多的程序设计题目中,都会涉及到素数的判断,那我们该如何有效判断素数呢?

2.素数的两种判断方法

(1)暴力法

从 2 到 √n

根据素数的定义,我们可以使用逐个试除的方式来判断素数,如果能为要判断的数找到一个除了1和自身以外的因数,那么它就是合数;反之,就是素数。

而这样的因数的范围必然在 2 ~ √n之间,所以我们便可以得到以下代码。

int isPrime(int n)
{
	if(n <= 1)
	{
		return 0;
	}
	for (int i = 2; i * i <= n; i++)
	{
		if (n % i == 0)
		{
			return 0;
		}
	}
	return 1;
}

该函数就可以判断输入的数是否为素数。

这个范围还可以更进一步地缩小。

6n-1与6n+1

数学上有一个定理,除了2和3外,只有形如6n-1和6n+1的自然数可能是素数,这里的n是大于等于1的整数。

如何理解这个定理呢?

所有自然数都可以写成6n,6n+1,6n+2,6n+3,6n+4,6n+5这6种。 那么我们就可以得到下表。

自然数是否可能是素数
6n不可能,为2的倍数
6n+1可能
6n+2不可能,为2的倍数
6n+3不可能,为3的倍数
6n+4不可能,为2的倍数
6n+5可能

其中6n+5可以写作6n-1,所以除了2和3的素数必然形如6n-1或6n+1。

于是我们可以写出如下代码。

int isPrime(int n)
{
	if(n <= 1) return 0;
	else if(n == 2 || n == 3) return 1;
	else if(n % 6 != 1 && n % 6 != 5) return 0;
	for (int i = 5; i * i <= n; i++)
	{
		if (n % i == 0)
		{
			return 0;
		}
	}
	return 1;
}

优化后的算法具有更高的效率。

(2)筛法

暴力算法虽然可以判断某个数是否为素数,但是当它面对大量需要判断的数据时,它的效率会显得十分低下,我们也有更好地方法来求一定范围里的素数,它就是我们的筛法。

筛法,顾名思义,就是将合数从数据中筛除,剩下的自然就都是素数了。

筛法也分为两种,让我们来逐一介绍。

埃氏筛

埃拉托斯特尼 筛法,简称 埃氏筛,是一种由希腊数学家埃拉托斯特尼所提出的一种简单检定素数的算法。

要得到自然数n以内的全部素数,必须把不大于根号n的所有素数的倍数剔除,剩下的就是素数。

下面的程序就是通过埃氏筛判断 0 ~ MAXSIZE-1是否为素数。

#define MAXSIZE 10000
int isPrime[MAXSIZE] = { 0 };
void sieveOfEratosthenes()
{
	for (int i = 2; i < MAXSIZE; i++)
	{
		isPrime[i] = 1;
	}
	for (int i = 2; i * i < MAXSIZE; i++)
	{
		if (isPrime[i])
		{
			for (int j = i * 2; j < MAXSIZE; j += i)
			{
				isPrime[j] = 0;
			}
		}
	}
}

埃氏筛的时间复杂度是O(n*loglogn),效率相较于原来的暴力算法已经有了很大的提高,但它仍然有具有一定的不足。

对于多个素数的公倍数,可能会被多次筛去。

为了解决这个问题,数学家欧拉优化了算法,于是就有了新的筛法。

欧拉筛

欧拉筛法,简称欧拉筛或是欧式筛,又因为其O(n)的时间复杂度而被称为线性筛。

欧拉筛将合数分解为(最小质因数 * 一个合数)的形式,通过最小质因数来判断当前合数是否已经被标记过,与埃氏筛相比,不会对已经被标记过的合数再进行重复标记,故效率更高。

下面的程序就是通过欧拉筛判断 0 ~ MAXSIZE-1是否为素数。

#define MAXSIZE 10000
int isPrime[MAXSIZE] = { 0 };
int prime[MAXSIZE];
int cnt = 0;
void sieveOfEuler()
{
	for (int i = 2; i < MAXSIZE; i++)
	{
		prime[i] = 1;
	}
	for (int i = 2; i * i < MAXSIZE; i++)
	{
		if (isPrime[i])
		{
			prime[++cnt] = i;
		}
		for (int j = 1; i * prime[j] < MAXSIZE; j++)
		{
			isPrime[i * prime[j]] = 0;
			//若i为prime[j]的倍数,终止循环,避免重复筛除
			if (i % prime[j] == 0)
                break;
		}
	}
}

在求一定范围中的所有素数时,欧拉筛具有无可比拟的优势,在程序设计中也经常被采用。

到此这篇关于c++两种素数判定方法的文章就介绍到这了,更多相关C++素数判定内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: C++两种素数判定方法

本文链接: https://lsjlt.com/news/172162.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • C++两种素数判定方法
    目录1.什么是素数2.素数的两种判断方法(1)暴力法从 2 到 √n6n-1与6n+1(2)筛法埃氏筛欧拉筛1.什么是素数 素数又称质数。一个大于1的自然数,除了1和它自...
    99+
    2022-11-13
    C++ 素数判定 C++ 素数
  • absolute定位css元素居中的两种方法
    有两种方法可以使绝对定位的CSS元素居中:1. 使用transform属性:可以使用CSS的transform属性来将绝对定位的元素...
    99+
    2023-09-14
    css
  • Python-两种方法实现输出素数(质数)
    方案一: 程序的设计为: 设为被除数,取值范围可以自行设定,本例设为3-100;(1、2均不是素数) 设计为除数,除数的取值范围为除掉1和自身以及比自身大的数字(当被除数本身不为0时,除以比自身大的数余数一定不为零。) 在这两个前提下,先让...
    99+
    2023-10-24
    python
  • java 数组新增元素的两种方法
    数组在使用前,长度就已固定,所以原数组长度是不能再改变了,基于此,提供如下两种方式,添加元素数据 1创建一个新数组,长度为原数组加1,然后将原数组数据添加到新数组,最后再添加需要的新数据         String[] s1 = {"a"...
    99+
    2023-09-03
    算法 开发语言 java
  • Java数组添加元素的两种方法
    目录说在前面方式一:方式二:说在前面 数组在使用前,长度就已固定,所以原数组长度是不能再改变了,基于此,提供如下两种方式,给数组添加数据。具体代码如下 方式一: 创建一个新数组,长度...
    99+
    2023-05-17
    Java 数组添加元素 Java数组
  • java 数组添加元素的两种方法
    说在前面 数组在使用前,长度就已固定,所以原数组长度是不能再改变了,基于此,提供如下两种方式,给数组添加数据。具体代码如下 方式一: 创建一个新数组,长度为原数组加1,然后将原数组数据添加到新数组,最后再添加需要的新数据 @Test ...
    99+
    2023-08-16
    java jvm 数组 开发语言 数据结构
  • C语言输入一个数判断是否为素数的多种方法
    目录1.  第一种方法2.第二种方法3.第三种方法4.第四种方法(函数实现)总结 需要解决这个问题,首先我们要明白-------->什么是素数? ...
    99+
    2023-05-17
    c语言如何判断素数代码 c语言判断素数 判断输入的数是否为素数
  • c语言素数的判断方法有哪些
    判断一个数是否为素数的常见方法有以下几种:1. 蛮力法:该方法是最简单直接的方法,即对于给定的数n,从2开始遍历到n-1,判断n是否...
    99+
    2023-10-20
    c语言
  • css3怎么隐藏元素(两种方法)
    CSS3 隐藏技术让你有效控制页面布局和内容展示在网页制作中,CSS3 提供了许多优秀的技术,让开发者能够更加灵活地控制网页的布局与内容展示。其中,CSS3 隐藏技术是一种非常重要的技术,可以让你在网页中隐藏一些不需要展示的内容,从而让页面...
    99+
    2023-05-14
  • c# 向MySQL添加数据的两种方法
           下面介绍两种执行SQL命令的方法,并作出相应地总结,第一种介绍一种常规用法,下面进行做简要地分析,首先我们需要执行打开数据库操作首先创建一个M...
    99+
    2022-05-26
    c# mysql c# 添加数据
  • JVM 判定对象是否死亡的两种方式
    引用计数法:(脑门刻字法)和 可达性分析 引用计数算法 引用计数器的算法是这样的:在对象中添加一个引用计数器,每当有一个地方引用它时,计数器值就加一;当引用失效时,计数器值就减一;任何时刻计数器为零的对象就是不可能再被使用的。 实现简单,效...
    99+
    2023-08-30
    jvm java 开发语言
  • C语言中判断素数(求素数)的思路与方法实例
    目录前言思路1实现:思路2实现:《C与指针》4.14 - 2:补充:判断素数的4种方法实例总结前言 素数又称质数。所谓素数是指除了 1 和它本身以外,不能被任何整数整除的数,例如17...
    99+
    2024-04-02
  • Python爬虫Xpath定位数据的两种方法
    方法一:直接右键,将文章路径复制下来点击Copy full Xpath 使用selenium+lxml中的etree进行配合使用,使用etree解析html网页 import req...
    99+
    2024-04-02
  • js判断两个数组相等的5种方法实例
    目录前言一、 toString()二、join()三、 JSON.stringify()四、sort()五、filter()总结 前言 在 js 中是不能直接用 == 或者...
    99+
    2024-04-02
  • jquery怎么删除dom元素(两种方法)
    在前端开发中,我们经常需要通过代码来操作网页上的Dom元素,其中一个常见需求是删除Dom元素。今天我们就来讨论如何使用jQuery来删除Dom元素。一、 jQuery的基本语法在使用jQuery删除Dom元素之前,我们需要先了解一些关于jQ...
    99+
    2023-05-14
  • c# 两种发送邮件的方法
    目录一、两种发送邮件的方法二、遇到的问题 三、示例System.Web.MailSystem.Net.Mail一、两种发送邮件的方法 有用到两种方式发邮件,一种是用Syst...
    99+
    2024-04-02
  • python元组tuple添加元素的两种方法
    python元组tuple添加元素的两种方法 方法一:可以使用python内置的__add__()方法,使用该方法为python元组添加元素时,需要使用元组来对象来进行调用,然后将需要添加的元素,以元组的数据类型进行传递,该方法并需修改调用...
    99+
    2023-09-01
    python 开发语言 数据结构
  • win7定时关机设置两种方法
    1. 使用Windows任务计划程序设置定时关机:- 打开“开始”菜单,搜索并打开“任务计划程序”。- 在任务计划程序窗口中,点击左...
    99+
    2023-09-01
    win7
  • (asp.net c#)DropDownList绑定后显示对应的项的两种方法
    方法一: 实现代码 复制代码 代码如下: DropDownList1.DataSource = listSort; DropDownList1.DataTextField = "Lo...
    99+
    2022-11-21
    DropDownList 绑定
  • C语言实现猜数字游戏的两种方法
    目录前言一、游戏描述二、代码实现1.生成游戏菜单2.构建主函数 3.构建游戏函数 三、二分法实现猜数前言 猜数字小游戏是我们大多数人学习C语言时都会了解到的一个有...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作