用c语言输出100-200之间所有的素数。
时间: 2023-06-14 21:07:05 浏览: 120
以下是使用C语言输出100-200之间所有素数的代码:
```c
#include <stdio.h>
#include <stdbool.h>
bool is_prime(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() {
printf("100-200之间的素数有:\n");
for (int i = 100; i <= 200; i++) {
if (is_prime(i)) {
printf("%d ", i);
}
}
printf("\n");
return 0;
}
```
该代码中,使用函数`is_prime()`判断一个数是否为素数。如果该数小于等于1,则不是素数;如果该数可以被2到该数平方根之间的任何一个数整除,则不是素数;否则就是素数。在主函数中,循环遍历100到200之间的所有整数,如果某个数是素数,则将其输出。
相关问题
用c语言输出100-1000 之间的水仙花数,输出100-1000 之间的素数
在C语言中,我们可以编写两个函数分别用于检查数字是否是水仙花数(又称哈士其数)以及素数。这里是一个简单的示例:
```c
#include <stdio.h>
#include <stdbool.h>
// 检查一个数字是否是水仙花数
bool is_armstrong(int num) {
int original_num = num;
int sum = 0;
while (num != 0) {
int digit = num % 10;
sum += digit * digit * digit;
num /= 10;
}
return original_num == sum;
}
// 检查一个数字是否是素数
bool is_prime(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() {
// 输出100到1000之间的水仙花数
printf("水仙花数(100-1000):\n");
for (int i = 100; i <= 1000; i++) {
if (is_armstrong(i))
printf("%d ", i);
}
// 输出100到1000之间的素数
printf("\n素数(100-1000):\n");
for (int i = 100; i <= 1000; i++) {
if (is_prime(i))
printf("%d ", i);
}
return 0;
}
```
在这个程序中,`is_armstrong()` 函数计算输入数字各位立方之和,如果等于原数字,则是水仙花数。而 `is_prime()` 则通过循环遍历判断一个数字是否有除1和自身以外的因子。
用c语言输出1-100之间的素数 codeblocks编译器
在C语言中,你可以使用循环和条件判断来输出1到100之间的素数。素数是指只有1和其本身两个正因数的大于1的自然数。以下是使用Code::Blocks编译器的一个简单示例:
```c
#include <stdio.h>
// 判断是否为素数的函数
int is_prime(int num) {
if (num <= 1)
return 0;
for (int i = 2; i * i <= num; i++) { // 只需检查到num的平方根即可
if (num % i == 0)
return 0; // 如果找到因子,则不是素数
}
return 1; // 没有找到因子,所以是素数
}
int main() {
int i;
printf("素数列表(1-100):\n");
for(i = 2; i <= 100; i++) {
if(is_prime(i))
printf("%d ", i);
}
return 0;
}
```
在这个程序中,我们首先定义了一个`is_prime`函数,用于检测给定数字是否为素数。然后在主函数`main`中,从2遍历到100,对每个数调用`is_prime`,如果是素数就打印出来。
阅读全文