设计一个c++程序, 输入N, 输出0~N之间的所有素数
时间: 2024-03-18 16:41:58 浏览: 70
以下是实现该功能的 C++ 代码:
```cpp
#include <iostream>
#include <cmath>
using namespace std;
bool isPrime(int n) {
if (n == 2) {
return true;
}
if (n % 2 == 0 || n == 1) {
return false;
}
int sqrt_n = sqrt(n);
for (int i = 3; i <= sqrt_n; i += 2) {
if (n % i == 0) {
return false;
}
}
return true;
}
int main() {
int n;
cout << "请输入N:" << endl;
cin >> n;
cout << "0~" << n << "之间的素数有:" << endl;
for (int i = 2; i <= n; i++) {
if (isPrime(i)) {
cout << i << " ";
}
}
cout << endl;
return 0;
}
```
该程序首先定义了一个判断素数的函数 `isPrime(int n)`,然后在 `main()` 函数中读取用户输入的 `n`,然后遍历 `2` 到 `n` 的所有数,判断是否为素数,如果是,则输出。
阅读全文