C语言,输出区间[101,1001]间所有的素数,每行输出6个数据,每列数据左对齐
时间: 2024-06-01 16:09:14 浏览: 95
以下是代码实现:
#include <stdio.h>
int is_prime(int n) // 判断是否是素数
{
if (n <= 1) {
return 0;
}
for (int i = 2; i <= n / 2; i++) {
if (n % i == 0) {
return 0;
}
}
return 1;
}
int main()
{
int count = 0; // 记录已输出的素数个数
for (int i = 101; i <= 1001; i++) {
if (is_prime(i)) {
printf("%-6d", i);
count++;
if (count % 6 == 0) {
printf("\n");
}
}
}
return 0;
}
希望能够帮到你。
相关问题
用c语言编程实现每5个数据一行方式输出101~200之间的所有素数
```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(){
int cnt = 0;
for(int i=101;i<=200;i++){
if(is_prime(i)){
printf("%d ", i);
cnt++;
if(cnt%5==0) printf("\n");
}
}
return 0;
}
```
C语言输出100之内所有素数,每行仅输出5个素数
C语言中输出100以内所有素数,可以采用循环和条件判断的方式来实现。这里是一个简单的程序示例:
```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;
}
void print_primes(int limit, int count) {
int counter = 0;
for (int i = 2; i <= limit; i++) {
if (is_prime(i)) {
printf("%d ", i);
counter++;
if (counter % count == 0) {
printf("\n"); // 每打印完count个素数换行
}
}
}
}
int main() {
print_primes(100, 5); // 输出100以内的素数,每行5个
return 0;
}
```
这个程序首先定义了一个`is_prime`函数来检查是否是素数,然后通过`print_primes`函数遍历1到100之间的数字,如果找到素数就输出,并保持计数器`counter`,当计数达到5时换行。
阅读全文