为什么我的质数检查代码不能显示正确的输出?

Why is my prime number checking code not displaying the correct output?(为什么我的质数检查代码不能显示正确的输出?)
本文介绍了为什么我的质数检查代码不能显示正确的输出?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个代码,它检查一个数字是否为质数,并相应地输出"是"或"否"。但当我输入1763时,即使它不是质数,它也会输出"是"。该代码通过检查一个数字是否可以被2和n-1之间的任何数字整除来检查该数字是否为质数。所以当我输入1763时,它应该输出"No",因为1763可以被41整除。我的代码中出了什么问题?

def getNumber():
    n=int(input())
    return n

def isPrime(n):
    if n==2:
        print("Yes")
    else:
        for i in range (2,n):
            if n%i==0:
                print("No")
                break
            else:
                print("Yes")
                break

def main():
    n = getNumber()
    isPrime(n)

main()

推荐答案

问题是您没有考虑到所有的除数。一旦第一个条件(if n%i==0:)为假,就执行第二个elif条件并输出"Yes"。

解决方案:您可以使用仅当找到除数时才变为1的标志,这意味着该数字不是质数。以下是您的代码稍作修改(仅显示部分代码,其余代码与您的代码相同)。正如@Bereal在注释中指出的那样,您不需要向上迭代到n,只需要向上迭代到平方根sqrt(n)math.ceil返回最接近的舍入整数。

import math
def isPrime(n):
    flag = 0
    if n==2:
        print("Yes")
        return
    else:
        # for i in range (2, n):
        for i in range (2, math.ceil(np.sqrt(n)) + 1):
            if n%i==0:
                print("No")
                flag = 1
                break

    if not flag:
        print ("Yes")

1763
No

这篇关于为什么我的质数检查代码不能显示正确的输出?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Leetcode 234: Palindrome LinkedList(Leetcode 234:回文链接列表)
How do I read an Excel file directly from Dropbox#39;s API using pandas.read_excel()?(如何使用PANDAS.READ_EXCEL()直接从Dropbox的API读取Excel文件?)
subprocess.Popen tries to write to nonexistent pipe(子进程。打开尝试写入不存在的管道)
I want to realize Popen-code from Windows to Linux:(我想实现从Windows到Linux的POpen-code:)
Reading stdout from a subprocess in real time(实时读取子进程中的标准输出)
How to call type safely on a random file in Python?(如何在Python中安全地调用随机文件上的类型?)