素数回文
#include
#include
#include
#include
using namespace std;

int digits(long long num) {
    int count = 0;
    while(num != 0) {
        num /= 10;
        count++;
    }
    return count;
}

bool isprime(long long n) {
    if (n <= 1) return false;
    if (n <= 3) return true;
    if (n % 2 == 0 || n % 3 == 0) return false;
    for (long long i = 5; i * i <= n; i += 6) {
        if (n % i == 0 || n % (i + 2) == 0)
            return false;
    }
    return true;
}

int main() {
    long long a, b = 0;
    cin >> a;
    int cnt = digits(a);
    long long c = a / 10;
    while (a > 0) {
        b = b * 10 + a % 10;
        a = a / 10;
    }
    long long e = pow(10, cnt);
    long long j = c * e;
    long long i = j + b;
    if (isprime(i)) {
        cout << "prime" << endl;
    } else {
        cout << "noprime" << endl;
    }
    return 0;
}
全部评论

相关推荐

06-17 21:57
门头沟学院 Java
白友:噗嗤,我发现有些人事就爱发这些,明明已读不回就行了,就是要恶心人
点赞 评论 收藏
分享
程序员小白条:找的太晚,别人都是大三实习,然后大四秋招春招的,你大四下了才去实习,晚1年
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
今天 13:54
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务