#include<stdio.h>
int main()
{
int n,i=2,a;
scanf("%d",&n);
while(i<=n){
if(n % i == 0){
printf("%d is prime.\n",n);
i++;
a=i;
}
}
if(n % a != 0){
printf("%d is not prime.\n",n);
}
return 0;
}
判断素数,经常判断不出来
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
2条回答 默认 最新
qfl_sdu 2021-09-26 17:57关注你的逻辑错了。
#include<stdio.h> int main() { int n,i=2,a = 0; scanf("%d",&n); while(i<n){ //不能等于 if(n % i == 0){ //n能整除i,说明不是素数 printf("%d is not prime.\n",n); //这里应该是no a=1; //作为一个标记 break; } i++; //i++应该在if外面 } if(a == 0){ printf("%d is prime.\n",n); } return 0; }本回答被题主选为最佳回答 , 对您是否有帮助呢?评论 打赏 举报解决 1无用 1