Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/cplusplus/140.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C++ 程序为一些条目提供了错误的输出!什么';怎么了?_C++ - Fatal编程技术网

C++ 程序为一些条目提供了错误的输出!什么';怎么了?

C++ 程序为一些条目提供了错误的输出!什么';怎么了?,c++,C++,下面是代码: #include <iostream> using namespace std; bool prime(int); int main() { int x; cout<<"Enter your number: "; cin>>x; if(prime(x) == true) cout<<"Number is prime"; if(prime(x) == false)

下面是代码:

#include <iostream>
using namespace std;
bool prime(int);

int main() 
{
    int x;
    cout<<"Enter your number: ";
    cin>>x;
    if(prime(x) == true)
        cout<<"Number is prime";
    if(prime(x) == false)
        cout<<"Number is not prime";
    return 0;
}
bool prime(int number)
{
    for(int i=2; i<number;i++)
    {
        if(number%i==0)
            return false;
        if(number%i!=0)
            return true;
    }
}
#包括
使用名称空间std;
布尔素数(int);
int main()
{
int x;
coutx;
如果(素数(x)=真)

cout复合物不是素数,所有非素数都会发出“数字不是素数”

但您需要修改代码:

bool prime(int number)
{
    for(int i=2; i<number;i++)
    {
        if(number%i==0)
            return false;
    }
    return true;
}
bool素数(整数)
{

对于(inti=2;i复合物不是素数,所有非素数都会发出“数字不是素数”

但您需要修改代码:

bool prime(int number)
{
    for(int i=2; i<number;i++)
    {
        if(number%i==0)
            return false;
    }
    return true;
}
bool素数(整数)
{

对于(int i=2;i
prime
函数,应如下所示

bool prime(int number)
{
   for(int i=2; i*i<number;i++) //Only till square root is enough.
   {
       //For any number which is divisible, return false.
       if(number%i==0)
           return false;

   }

   //Else, divisible by no one is prime.
   return true;
bool素数(整数)
{

对于(int i=2;i*i
prime
函数,应如下所示

bool prime(int number)
{
   for(int i=2; i*i<number;i++) //Only till square root is enough.
   {
       //For any number which is divisible, return false.
       if(number%i==0)
           return false;

   }

   //Else, divisible by no one is prime.
   return true;
bool素数(整数)
{

对于(int i=2;i*i使用调试器跟踪所述失败测试的执行。您可以共享您失败的测试用例号吗?它不应该说复合数不是素数吗?
返回true;
语句仅在循环后有效。只有这样,您才能测试
i
的所有值。这与您的特定pro无关问题,但是如果有if(prime(x))和else语句而不是if(prime(x)==false,不是会容易得多吗?使用调试器跟踪所述失败测试的执行。您可以共享失败测试用例号吗?不应该说复合数不是素数吗?
返回true;
语句仅在循环后有效。只有这样,您才能测试
i
的所有值。这与您的特定问题有些无关,但用if(prime(x))和else语句代替if(prime(x)=false不是更容易吗?注意这个答案中的一些效率:注意这个答案中的一些效率: