Python 判断是否为质数或素数的实例

作者:欠你一颗糖 时间:2023-06-18 15:35:35 

一个大于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,质数,素数
0
投稿

猜你喜欢

  • asp长文章分页显示思路

    2007-08-23 13:54:00
  • python创建文件时去掉非法字符的方法

    2023-10-12 02:15:51
  • 详解element-ui 表单校验 Rules 配置 常用黑科技

    2023-08-17 17:42:47
  • Python多进程模式实现多核CPU并行计算

    2022-12-01 21:26:20
  • 解决Python正则表达式匹配反斜杠''\\''问题

    2022-06-19 09:10:55
  • Array.prototype.slice

    2010-05-07 12:43:00
  • 关于python处理大型json文件的方法

    2023-09-24 12:47:47
  • SQL Server 2005作业设置定时任务

    2024-01-27 13:02:59
  • BigPipe:高性能的"流水线技术"网页

    2010-11-02 12:47:00
  • uniapp实现微信小程序的电子签名效果(附demo)

    2024-04-19 09:55:39
  • Python paramiko模块的使用示例

    2021-05-12 20:30:00
  • Python button选取本地图片并显示的实例

    2023-10-06 15:56:32
  • jQuery中ajax和post处理json的不同示例对比

    2024-04-16 08:54:10
  • MySQL 学习总结 之 初步了解 InnoDB 存储引擎的架构设计

    2024-01-26 10:15:38
  • 详解Go语言中用 os/exec 执行命令的五种方法

    2024-05-28 15:21:51
  • 浅析python函数式编程

    2022-07-14 22:39:16
  • django框架两个使用模板实例

    2023-11-01 20:05:18
  • python实现差分隐私Laplace机制详解

    2022-01-08 16:37:41
  • 利用Pycharm + Django搭建一个简单Python Web项目的步骤

    2021-10-21 15:35:47
  • 从零开始学习Node.js系列教程二:文本提交与显示方法

    2024-05-08 09:35:30
  • asp之家 网络编程 m.aspxhome.com