【C语言】统计对称素数

对称素数 = 既是素数(只能被 1 和自身整除的大于 1 的整数),又是回文数(正读和反读都相同的数,如 131、151)。

实现思路

把问题拆分为两个核心子功能,再组合判断:

  1. 判断素数:排除小于 2 的数,遍历 2 到√n,判断是否能被整除;
  2. 判断回文数:将数字反转,比较反转后的数是否等于原数;
  3. 组合判断:只有同时满足 "素数" 和 "回文数",才是对称素数。
cpp 复制代码
#include <stdio.h>   
#include <math.h>    
#define _CRT_SECURE_NO_WARNINGS 1

// 判断是否为素数
bool isPrime(int n) {
     //小于2的数不是素数
    if (n < 2) {
        return false;
    }
    int i = 2;
    // 只需遍历到√n(减少循环次数)
    for (i=2; i * i <= n; i++) {
        // 能被整除,不是素数
        if (n % i == 0) {  
            return false;
        }
    }
    return true;
}

// 判断是否为回文数(对称数)
bool isPalindrome(int n) {
    // 负数不是回文数(对称素数只考虑正整数)
    if (n < 0) {
        return false;
    }
    int original = n;  // 保存原数
    int reversed = 0;  // 存储反转后的数

    // 反转数字
    while (n > 0) {
        // 取最低位拼到反转数中
        reversed = reversed * 10 + n % 10;  
        // 丢弃最低位
        n = n / 10;                         
    }

    // 反转后等于原数,就是回文数
    return reversed == original;
}

// 判断是否为对称素数
bool isSymmetricPrime(int n) {
    // 必须同时满足:是素数 + 是回文数
    return isPrime(n) && isPalindrome(n);
}

int main()
{
    // 输出 5 位以内的全部对称素数
    for (int i = 2; i < 9999; ++i) {
        int res = isSymmetricPrime(i);
        if(res)
            printf("%d\n",i);
    }
    
	return 0;
}
相关推荐
Cando学算法2 分钟前
回声服务器项目
linux·开发语言·c++·计算机网络·ubuntu
宝耶2 分钟前
[特殊字符] 操作日志模块复习笔记
java·开发语言·jvm
好好研究3 分钟前
Java基础学习(十三):IO流基础
java·开发语言·学习·io流
知识分享小能手10 分钟前
R语言入门学习教程,从入门到精通,R语言传统绘图系统 - 完整知识点与案例代码(2)
开发语言·学习·r语言
代龙涛15 分钟前
WordPress archive.php 分类与归档页面开发指南
开发语言·后端·php·wordpress
格林威17 分钟前
面阵相机 vs 线阵相机:堡盟与大恒相机选型差异全解析 附C++ 实战演示
开发语言·c++·人工智能·数码相机·计算机视觉·视觉检测·工业相机
xyq202420 分钟前
相邻节点迭代器
开发语言
YSF2017_320 分钟前
C语言15-makefile(2)——makefile的自定义变量及两个函数
c语言·开发语言
YaBingSec21 分钟前
玄机靶场—Apache-druid(CVE-2021-25646) WP
java·开发语言·笔记·安全·php·apache
少控科技23 分钟前
小数典应用:农场环境数据采集监控
开发语言·windows·c#