王鹿其 发表于 2023-10-28 11:27:02

为什么没有输出结果

#include<iostream>
using namespace std;
int main()
{
    int arr;
    for(int i=0;i<999;i++)
    {
      arr[ i]=i+2;
      int j;
      for(int j=2;j<arr[ i];j++)
      {
            if(arr[ i]%j==0)
                break;
      }
      if(j==arr[ i])
            cout<<arr[ i]<<"";
    }
    return 0;
}

isdkz 发表于 2023-10-28 11:27:11

问题在于变量 j 在for循环外已经被声明,再次在for循环内部重新声明,导致for循环内部的 j 和外部的 j 是两个不同的变量。因此,for循环内部的 j 没有被初始化,导致无法正确判断 arr[ i] 是否为素数。

要解决这个问题,只需将for循环内部的 int j; 语句移动到for循环的外部即可。修改后的代码如下:

#include<iostream>
using namespace std;
int main()
{
    int arr;
    for(int i=0;i<999;i++)
    {
      arr[ i]=i+2;
      int j; // 将此行移到for循环的外部
      for(j=2;j<arr[ i];j++)
      {
            if(arr[ i]%j==0)
                break;
      }
      if(j==arr[ i])
            cout<<arr[ i]<<"";
    }
    return 0;
}


这样,变量 j 就能正确地在for循环内部进行初始化和判断,代码就能输出结果了。

陶远航 发表于 2023-10-28 12:40:15

您的代码有一些错误,这可能会导致它无法正确地找到2到1000的所有素数。以下是一个修正后的版本:

#include<iostream>
using namespace std;

bool isPrime(int num) {
    if (num <= 1) {
      return false;
    }
    for (int i = 2; i * i <= num; i++) {
      if (num % i == 0) {
            return false;
      }
    }
    return true;
}

int main() {
    for (int i = 2; i <= 1000; i++) {
      if (isPrime(i)) {
            cout << i << " ";
      }
    }
    return 0;
}

在这个版本中,我们创建了一个名为`isPrime`的函数,该函数检查一个数是否为素数。然后,我们在主函数中遍历2到1000的所有数字,并使用`isPrime`函数来检查每个数字是否为素数。如果是,我们就打印出这个数字。
页: [1]
查看完整版本: 为什么没有输出结果