本题的目标很简单,就是判断一个给定的正整数是否素数。
输入格式:
输入在第一行给出一个正整数N
(≤ 10),随后N
行,每行给出一个小于231的需要判断的正整数。
输出格式:
对每个需要判断的正整数,如果它是素数,则在一行中输出Yes
,否则输出No
。
输入样例:
2
11
111
输出样例:
Yes
No
题解思路:
暴力试除法,注意判断1
题解代码:
#include <iostream>
using namespace std;
int n;
bool is_prime (int x){
for (int i = 2; i <= x / i; i++){
if (x % i == 0){
return false;
}
}
if (x == 1){
return false;
}
return true;
}
int main (){
cin >> n;
while (n--){
int a;
cin >> a;
if (is_prime (a)){
cout << "Yes" << endl;
}else{
cout << "No" << endl;
}
}
}