C语言编写程序: 五位以内的对称素数 题目描述 判断一个数是否为对称且不大于五位数的素数。 意思是小于100,000的数 输入 第一行:测试数据组数T 接下来包含T行,每行由1个不大于五位数的正整数构成。 输出 对于每个正整数,如果该数是不大于五位数的对称素数,则输出”Yes”,否则输出”No”,每个判断结果单独列一行。
时间: 2023-06-14 12:06:46 浏览: 112
大一C语音程序设计基础期末程序题,填空题,复习题
以下是C语言的代码实现:
```c
#include <stdio.h>
#include <stdbool.h>
bool isPrime(int n) { // 判断素数
if (n <= 1) {
return false;
}
for (int i = 2; i * i <= n; i++) {
if (n % i == 0) {
return false;
}
}
return true;
}
bool isSymmetric(int n) { // 判断回文数
int temp = n;
int reverse = 0;
while (temp > 0) {
reverse = reverse * 10 + temp % 10;
temp /= 10;
}
return n == reverse;
}
int main() {
int t; // 测试数据组数
scanf("%d", &t);
while (t--) {
int n;
scanf("%d", &n);
if (isSymmetric(n) && isPrime(n)) {
printf("Yes\n");
} else {
printf("No\n");
}
}
return 0;
}
```
首先定义两个函数 `isPrime` 和 `isSymmetric`,分别用于判断素数和回文数。在 `main` 函数中,从输入读入测试数据组数 `t`,然后循环读入每个需要判断的正整数 `n`,判断该数是否为对称素数并输出判断结果。
阅读全文