Python 判断是否为质数或素数

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python 判断是否为质数或素数相关的知识,希望对你有一定的参考价值。

一个大于1的自然数,除了1和它本身外,不能被其他自然数(质数)整除(2, 3, 5, 7等),换句话说就是该数除了1和它本身以外不再有其他的因数。

首先我们来第一个传统的判断思路:

def handlerNum(num):
# 质数大于 1
if num > 1:
# 查看是否有其他因子
for i in range(2, num//2+1):
if (num % i) == 0:
print(num,"不是质数")
break
else:
print(num, "是质数")

# 如果输入的数字小于或等于 1,不是质数
else:
print(num, "不是质数")
if __name__ == ‘__main__‘:
# 用户输入一个数字
num = int(input("请输入一个数字: "))

# 调用函数处理方法
handlerNum(num)
  其实上面循环中的else和if并不是成对的,而是和for并排的,当然for和else搭配出现并不少见,慢慢地会有所体会的,这段代码的含义是,当for里面的条件都不满足时,就会执行else里面的代码。以上就是我们按照传统的思路来解题,其实还有一种更快,更简单的方法解题,那就是利用真或假来判断。
#处理函数
def IsPrime(num):
  #根据质数的定义,其必须大于0

if num == 1:
return False

  #循环需要判断的次数

for i in range(2, num // 2 + 1):
    #如果该数有其他的因子返回False,即不是质数

if num % i == 0:
return False
return True

if __name__ == ‘__main__‘:
    #输入一个数字 

num = eval(input("请输入一个数,判断是否为质数:"))
    #调用方法(如果是质数返回True,否则返回False),打印结果

print(IsPrime(num))
 这两种方法大体都差不多,只不过这给我们以后解决问题提供了一种新的思路。

 出处:
http://www.cnblogs.com/KBe24Love/p/7750418.html
  本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。







































以上是关于Python 判断是否为质数或素数的主要内容,如果未能解决你的问题,请参考以下文章

C语言编程:判断某数是不是是质数

判断任意数字是否为素数

C语言习题如何判断一个数字是否为素数(质数)?

PAT A1015 Reversible Primes (20分) [素数 质数 进制转换]

c语言判断一个数是不是为质数

算法与数据结构判断一个数是否是素数