广告
返回顶部
首页 > 资讯 > 后端开发 > Python >python高效的素数判断算法
  • 373
分享到

python高效的素数判断算法

2024-04-02 19:04:59 373人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

高效素数判断算法 算法概述 此算法将其他博主对基本素数算法的一些改进进行了整合,其中主要整合了如下三条规则: 1.大于3的素数一定在6的倍数前一个或后一个(如素数37在36的后面)

高效素数判断算法

算法概述

此算法将其他博主对基本素数算法的一些改进进行了整合,其中主要整合了如下三条规则:

1.大于3的素数一定在6的倍数前一个或后一个(如素数37在36的后面)

2.要判断n是否为素数,只需要让n从2开始,依次除到根号n即可

3.在进行“让n从2开始,依次除到根号n”过程中,若n除以2的余数不为0,可以直接跳过[2, sqrt(n)]里面的所有偶数

博主语文素养不高,表达不是很准确,在后面会对这三条规则进行解释。

规则详解

1.大于3的素数一定在6的倍数前一个或后一个(如素数37在36的后面)

任意一个整数n可以表示为n = 6a + b ( 0 <= b <= 5, a >= 0 ),接下来依次讲当n等于0到5的情况,以对此结论进行证明:

当n = 6a + 0 = 6a时,n有一个不为1及其本身的因数(素数判断条件)6,此类数不为素数

当n = 6a + 2 = 2( 3a + 1 )时,n有一个不为1及其本身的因数(素数判断条件)2,此类数不为素数

当n = 6a + 3 = 3( 2a + 1 )时,同上,有一因数3,此类数也不为素数

当n = 6a + 4 = 2( 3a + 2 )时,有一因数2, 此类数也不为素数

而当n = 6a + 1 或 n = 6a + 5时,不能绝对确定n是否为素数,需要考虑a的取值,显然此时的数值n就是分布在6的倍数前一个或后一个

总结:大于3的素数一定分布在6的倍数前后

  • 此规则可以直接对素数进行初步筛选,不符合此规则的数可直接判定为非素数,直接减少了2/3的运算量,效率提高肉眼可见
  • 注意小于等于3的素数(2, 3)需要另外判断

2.要判断n是否为素数,只需要让n从2开始,依次除到根号n即可

最基本的素数判断方法是:让n从2开始除,依次除到n - 1,如果每次除出来的结果余数皆不为0,那么此数n即为素数
实际上并不需要从除以[2, n - 1]区间的所有整数,只需除以[2, sqrt(n)]

3.在进行让n除以[2, sqrt(n)]区间内的所有整数操作时,如果2不是n的一个因数,那么之后可以不判断[2, sqrt(n)]区间的所有偶数

数学证明:当n/2除不尽时,n除以[2, sqrt(n)]区间内的所有偶数都除不尽

因此如果n不能将2除尽,那么之后的偶数一样除不尽,可以直接不除
如果将2除尽了,n就不是素数,直接排除
如果没有将2除尽,之后的计算量直接减半,肉眼可见的效率提升

算法时间复杂度复杂度

1.最基础的算法:也就是让n从2开始判断,一直到n-1

若遇到的数是素数时,此时需要进行n-2次判断
当遇到的不是素数时,要进行a(2<a<n-2)次判断
也就是说时间复杂度为n

2.改进后的算法:

根据规则二,判断素数只要从[2,sqrt(n)]即可,此时复杂度为sqrt(n)
根据规则3,无论如何都可以不判断2之后的偶数(当n大于2,当n除尽2时,n不为素数,之后不需要判断,如果n除不尽2时,之后的偶数不要判断)
假设n可以除尽2和不可以除尽2概率相等,那此时复杂度为sqrt(n)/4
根据规则一,只有1/3的数要进行判断,此时复杂度为sqrt(n)/12
也就是说时间复杂度为sqrt(n)/12

在计算过程中做出的假设以及计算过程并不那么严谨,此结果仅供参考

python代码实现


def primeJudge(n):
 #先将数分为三类, 小于等于1,大于1小于5,和大于等于5
 #非整数统统不是素数
 if not isinstance(n, int): return False
 #小于1等于的都不是素数
 if n <= 1: return False
 #大于1小于5
 elif n == 2 or n == 3: return True
 #大于等于5
 elif n >= 5:
  #先判断是否在6的附近
  if n % 6 == 5 or n % 6 == 1:
   #再判断是否可以将2除尽
   #可以的话不是素数
   if n % 2 == 0: return False
   else:
    #不可除尽2,直接跳过所有偶数
    for i in range(3, int(sqrt(n) + 1), 2):
     if n % i == 0: return False
    #经过筛选即为素数
    return True
  #不在6的附近不是素数
  else: return False

以上就是Python高效的素数判断算法的详细内容,更多关于python素数算法的资料请关注编程网其它相关文章!

--结束END--

本文标题: python高效的素数判断算法

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

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

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • python高效的素数判断算法
    高效素数判断算法 算法概述 此算法将其他博主对基本素数算法的一些改进进行了整合,其中主要整合了如下三条规则: 1.大于3的素数一定在6的倍数前一个或后一个(如素数37在36的后面) ...
    99+
    2022-11-12
  • PHP8中的函数:array_is_list()的高效判断方法
    在开发Web应用时, PHP是一个非常受欢迎的服务器端脚本语言,能够轻松构建动态的Web页面。而PHP8版本中的新特性让PHP开发更加方便和高效。其中一个新的函数是array_is_list(),可以用来判断一个数组是否索引数组,即数组下标...
    99+
    2023-05-16
    函数 PHP array_is_list()。
  • Python判断素数并输出的方法是什么
    判断一个数是否为素数的一种常见方法是使用试除法。试除法的基本思路是,对于每个可能的除数,检查它是否能整除给定的数。如果存在一个除数能...
    99+
    2023-08-23
    Python
  • Golang实战:判断字符是否为字母的高效算法
    Golang实战:判断字符是否为字母的高效算法,需要具体代码示例引言:在处理文本数据时,常常需要对字符进行判断和处理。其中一个常见的需求就是判断一个字符是否为字母。然而,由于字符编码的复杂性和多样性,传统的方法往往效率较低。本文将介绍一种高...
    99+
    2023-12-23
    Golang 高效算法 判断字符
  • 使用Python判断质数(素数)的简单方法讲解
    质数又称素数。指在一个大于1的自然数中,除了1和此整数自身外,不能被其他自然数整除的数。素数在数论中有着很重要的地位。比1大但不是素数的数称为合数。1和0既非素数也非合数。质数是与合数相对立的两个概念,二者...
    99+
    2022-06-04
    素数 质数 简单
  • python质数的判断方法
    这篇文章将为大家详细讲解有关python质数的判断方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。python质数判断的方法:首先运用python的数学函数;然后单行程序扫描素数,代码为【[ p for...
    99+
    2023-06-08
  • java判断素数的方法有哪些
    判断一个数是否为素数的常用方法有以下几种:1. 暴力法:从2开始逐个判断该数能否被整除,如果能被除以2至该数之前的任意数整除,则该数...
    99+
    2023-08-24
    java
  • Java中高效判断数组中是否包含某个元素的几种方法
    目录检查数组是否包含某个值的方法使用List使用Set使用循环判断使用Arrays.binarySearch()时间复杂度使用一个长度为1k的数组使用一个长度为10k的数组总结补充使...
    99+
    2022-11-12
  • java判断是否为素数(质数)的方法
    质数的定义:对于大于1的数,如果除了1和它本身,它不能再被其它正整数整除,那么我们说它是一个质数。判断一个数是否为质数(素数)方法:如果是偶数,直接返回;然后从3开始,步长为2,一直到n的算术平方根为止,都除不尽则为质数。Java程序:(推...
    99+
    2014-11-06
    java
  • python判断回文数的方法
    这篇文章给大家分享的是有关python判断回文数的方法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。python判断回文数的方法:首先将数组转为字符串;然后设置两个指针,一个从左往右遍历字符串,一个从右往左遍历,...
    99+
    2023-06-08
  • Python编程判断一个正整数是否为素数的方法
    本文实例讲述了Python编程判断一个正整数是否为素数的方法。分享给大家供大家参考,具体如下: import string import math #判断是否素数的函数 def isPrime(n): ...
    99+
    2022-06-04
    素数 方法 正整数
  • Python 判断是否为质数或素数的实例
    一个大于1的自然数,除了1和它本身外,不能被其他自然数(质数)整除(2, 3, 5, 7等),换句话说就是该数除了1和它本身以外不再有其他的因数。 首先我们来第一个传统的判断思路: def handle...
    99+
    2022-06-04
    素数 质数 判断是否
  • c语言素数的判断方法有哪些
    判断一个数是否为素数的常见方法有以下几种:1. 蛮力法:该方法是最简单直接的方法,即对于给定的数n,从2开始遍历到n-1,判断n是否...
    99+
    2023-10-20
    c语言
  • C语言中判断素数(求素数)的思路与方法实例
    目录前言思路1实现:思路2实现:《C与指针》4.14 - 2:补充:判断素数的4种方法实例总结前言 素数又称质数。所谓素数是指除了 1 和它本身以外,不能被任何整数整除的数,例如17...
    99+
    2022-11-13
  • python判断是否为整数的方法
    这篇文章给大家分享的是有关python判断是否为整数的方法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。python判断是否为整数的方法:1、使用【type()】函数判断,代码为【type(name, bases...
    99+
    2023-06-08
  • python判断质数的方法有哪些
    判断质数的方法有以下几种: 简单的方法是遍历从2到n-1的所有整数,判断n是否能被这些整数整除。如果n能被任何一个整数整除,则n不...
    99+
    2023-10-22
    python
  • python奇偶数判断的方法有哪些
    在Python中,可以使用以下几种方法来判断一个数是奇数还是偶数:1. 使用取模运算符(%):将给定的数与2进行取模运算,如果余数为...
    99+
    2023-08-23
    python
  • java中判断数组是否包含某元素的方法
    有两种方法可以判断数组是否包含元素:方法1, 将数组转换为list,然后使用list的contains方法来判断:Arrays.asList(...).contains(...)java.lang.String.contains() 方法返...
    99+
    2016-05-11
    java
  • python实现高效的遗传算法
    遗传算法属于一种优化算法。 如果你有一个待优化函数,可以考虑次算法。假设你有一个变量x,通过某个函数可以求出对应的y,那么你通过预设的x可求出y_pred,y_pred差距与你需要的...
    99+
    2022-11-12
  • Python判断回文数的三种方法实例
    需求: 从控制台输入一个五位数,如果是回文数就打印“是回文数”,否则打印“不是回文数”,例如:11111 12321 12221 “回文”是指正读反读都能读通的句子,它是古今中外都...
    99+
    2022-11-11
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作