创新互联Python教程: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))

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

分享题目:创新互联Python教程:python如何判断一个数是素数
当前URL:http://www.csdahua.cn/qtweb/news1/138651.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网