| 
 | 
 
 
发表于 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`函数来检查每个数字是否为素数。如果是,我们就打印出这个数字。 |   
 
 
 
 |