用C语言求出100~1000内所有素数(不用函数))
时间: 2024-01-29 19:03:11 浏览: 65
好的,下面是代码实现:
```c
#include <stdio.h>
int main() {
for (int i = 100; i <= 1000; i++) {
int is_prime = 1;
for (int j = 2; j * j <= i; j++) {
if (i % j == 0) {
is_prime = 0;
break;
}
}
if (is_prime) {
printf("%d ", i);
}
}
printf("\n");
return 0;
}
```
与使用函数的实现方式相比,这里我们直接在主函数中实现了判断一个数是否为素数的功能。具体来说,我们从 2 开始枚举到 $\sqrt{i}$,如果在该范围内存在一个数能够整除 $i$,则 $i$ 不是素数,否则 $i$ 是素数。
对于每个素数,我们输出它。最后,记得换行。
相关问题
用C语言求出100~1000内所有素数
好的,下面是代码实现:
```c
#include <stdio.h>
int is_prime(int n) {
if (n <= 1) {
return 0;
}
for (int i = 2; i * i <= n; i++) {
if (n % i == 0) {
return 0;
}
}
return 1;
}
int main() {
for (int i = 100; i <= 1000; i++) {
if (is_prime(i)) {
printf("%d ", i);
}
}
printf("\n");
return 0;
}
```
首先,我们需要一个判断一个数是否为素数的函数 `is_prime`,它的实现方式是从 2 开始枚举到 $\sqrt{n}$,如果在该范围内存在一个数能够整除 $n$,则 $n$ 不是素数,否则 $n$ 是素数。
接着,在主函数中,我们从 100 开始枚举到 1000,对于每个数,如果它是素数,则输出它。
最后,记得换行。
使用C语言求出1~n之间的所有素数之和
好的,我可以为您提供使用C语言求出1~n之间的所有素数之和的代码。
以下是使用C语言求出1~n之间的所有素数之和的代码:
```c
#include <stdio.h>
int is_prime(int num);
int main() {
int n, i, sum = 0;
printf("Enter a positive integer n: ");
scanf("%d", &n);
for (i = 2; i <= n; i++) {
if (is_prime(i))
sum += i;
}
printf("The sum of primes between 1 and %d is %d\n", n, sum);
return 0;
}
int is_prime(int num) {
int i;
if (num < 2)
return 0;
for (i = 2; i*i <= num; i++) {
if (num % i == 0)
return 0;
}
return 1;
}
```
其中,`is_prime`函数用于判断一个数是否为素数,如果是,则返回1,否则返回0。在`main`函数中,首先要求用户输入一个正整数n,然后使用循环遍历1~n之间的所有数,对于每个数,如果它是素数,则累加到`sum`变量中。最后输出1~n之间的所有素数之和。
希望能帮助到您!