看到蛮多参考是不考虑2本身的。
这里补了个2是素数的判断,并增加了对输入范围的检查以及打印次数的计数。
#include<stdio.h>
#include<math.h>
int is_prime(int n);
int main() {
int i ,a,b,c;
start://跳转标记-开始前
i = 0, a = 0, b = 0, c = 0;
printf("输入范围,空格隔开\n");
scanf("%d %d", &a, &b);
if (a < 2) {
printf("起始值过小,已设为2\n");
a = 2;
}
if (b < 2) {
printf("结束值过小,重新输入范围\n");
goto start;//跳转到开始前
}
printf("\n");
for (i = a; i <= b; i++) {
if (1 == is_prime(i)) {
printf(" %d ", i);
c++;//计数
if (0 == c % 10) {
printf("\n");
}//每打印10个换行一次
}
}
printf("\n范围[%d,%d],共%d个\n",a,b,c);
return 0;
}
int is_prime(int n) {
if (2 == n) {
return 1;
}//2也是素数
for (int i = 2; i<sqrt(n) + 1; i++) {
if (0==n%i)
return 0;
}
return 1;
}