编写一段c语言代码,要求如下:求出100~200之间的全部素数,每行输出8个数,每个数宽度为5列。 输出格式: 每行输出8个素数数,每个素数宽度为5列。 输出样例: 101 103 107 109 113 127 131 137 139 149 151 157 163 167 173 179 181 191 193 197 199
时间: 2023-12-28 22:03:45 浏览: 92
以下是代码实现:
```c
#include <stdio.h>
#include <math.h>
int is_prime(int n) {
if (n <= 1) {
return 0;
}
int sqr = sqrt(n);
for (int i = 2; i <= sqr; i++) {
if (n % i == 0) {
return 0;
}
}
return 1;
}
int main() {
int count = 0;
for (int i = 100; i <= 200; i++) {
if (is_prime(i)) {
printf("%5d", i);
count++;
if (count % 8 == 0) {
printf("\n");
}
}
}
return 0;
}
```
在这个程序中,我们首先定义了一个 `is_prime` 函数,用于判断一个数是否为素数。该函数接受一个整数参数 `n`,如果 `n` 是素数,则返回 1;否则返回 0。
接下来在 `main` 函数中,我们使用循环遍历 100~200 之间的所有数,对于每个数,调用 `is_prime` 函数进行判断,如果该数是素数,则输出其值,并将计数器 `count` 加 1。当 `count` 的值是 8 的倍数时,我们输出一个换行符,以便将输出分成多行,每行 8 个数。最后程序结束并返回 0。
阅读全文