获取不大于N的最大质数的C++程序
时间: 2024-04-30 14:17:42 浏览: 40
find_primes_java:Java
以下是获取不大于N的最大质数的 C 代码:
```c
#include <stdio.h>
#include <stdbool.h>
bool is_prime(int n) {
if (n < 2) {
return false;
}
for (int i = 2; i * i <= n; i++) {
if (n % i == 0) {
return false;
}
}
return true;
}
int max_prime(int n) {
for (int i = n; i >= 2; i--) {
if (is_prime(i)) {
return i;
}
}
return -1; // 没有找到质数
}
int main() {
int n = 100; // 例如,n=100
int max = max_prime(n);
if (max == -1) {
printf("没有找到质数\n");
} else {
printf("不大于%d的最大质数是%d\n", n, max);
}
return 0;
}
```
该程序首先定义了一个 ``is_prime`` 函数,用于判断一个数是否为质数。然后定义了一个 ``max_prime`` 函数,用于获取不大于给定数的最大质数。最后在 ``main`` 函数中调用 ``max_prime`` 函数并输出结果。
阅读全文