L1-028 判断素数(分数 10)

本题的目标很简单,就是判断一个给定的正整数是否素数。

输入格式:

输入在第一行给出一个正整数N(≤ 10),随后N行,每行给出一个小于231的需要判断的正整数。

输出格式:

对每个需要判断的正整数,如果它是素数,则在一行中输出Yes,否则输出No

输入样例:

2
11
111

输出样例:

Yes
No

问题分析:

注意特殊值1,其他的数字按照正常的判断就行

代码实现

#include<stdio.h>
#include<math.h>
int main(){
    int n;
    scanf("%d",&n);
    for(int i=0;i<n;i++){
        int k,flag=1;
        scanf("%d",&k);
        for(int j=2;j<=sqrt(k);j++){
            if(k%j==0){
                flag=0;
                break;
            }
        }
        if(i!=0){
            printf("\n");
        }
        if(flag&&k!=1){
            printf("Yes");
        }else{
            printf("No");
        }
    }
    return 0;
}

 


版权声明:本文为apprentice_eye原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。