C语言-详细讲解-P1217 [USACO1.5] 回文质数 Prime Palindromes

目录

1.题目要求

2.题目解读

3.代码实现


1.题目要求

2.题目解读

这道题主要考察了如何求回文数以及如何求质数,求质数可以看我之前的帖子C语言-详细讲解-6个代码让你素数问题从入门到精通

这里我们主要来看如何求回文数

3.代码实现

cpp 复制代码
#include <stdio.h>
#include <math.h>

// 判断一个数是否为质数
int is_prime(int num) {
    if (num < 2) return 0;  // 小于2的数不是质数
    if (num == 2) return 1;  // 2是质数
    if (num % 2 == 0) return 0;  // 大于2的偶数不是质数
    for (int i = 3; i <= (int)sqrt(num); i += 2) {  // 从3开始,以2为步长,遍历到num的平方根
        if (num % i == 0) return 0;  // 如果能被整除,不是质数
    }
    return 1;  // 遍历完没被整除,是质数
}

// 判断一个数是否为回文数
int is_palindrome(int num) {
    int original = num;
    int reversed_num = 0;
    while (num > 0) {
        //将 reversed_num 左移一位(乘以 10),然后加上 num 的最低位数字(num % 10)。这样就逐步构建出了原数的反转数字。
		reversed_num = reversed_num * 10 + num % 10;
        //这一步将 num 缩小 10 倍,去掉已经处理过的最低位数字,以便下一次循环处理更高位的数字。
        num /= 10;
    }
    return original == reversed_num;
}

int main() {
    int a, b;
    scanf("%d %d", &a, &b);
    // 确保a从奇数开始(因为除2外偶数不是质数)
    if (a % 2 == 0) a++;
    for (int num = a; num <= b; num += 2) {  // 只遍历奇数
        if (is_palindrome(num) && is_prime(num)) {
            printf("%d\n", num);
        }
    }
    return 0;
}

***新人博主创作不易,希望大家多多点赞关注呀~

相关推荐
QuantumStack21 分钟前
【C++ 真题】P1104 生日
开发语言·c++·算法
写个博客1 小时前
暑假算法日记第一天
算法
绿皮的猪猪侠1 小时前
算法笔记上机训练实战指南刷题
笔记·算法·pta·上机·浙大
hie988942 小时前
MATLAB锂离子电池伪二维(P2D)模型实现
人工智能·算法·matlab
杰克尼2 小时前
BM5 合并k个已排序的链表
数据结构·算法·链表
.30-06Springfield3 小时前
决策树(Decision tree)算法详解(ID3、C4.5、CART)
人工智能·python·算法·决策树·机器学习
我不是哆啦A梦3 小时前
破解风电运维“百模大战”困局,机械版ChatGPT诞生?
运维·人工智能·python·算法·chatgpt
xiaolang_8616_wjl3 小时前
c++文字游戏_闯关打怪
开发语言·数据结构·c++·算法·c++20
small_wh1te_coder3 小时前
硬件嵌入式学习路线大总结(一):C语言与linux。内功心法——从入门到精通,彻底打通你的任督二脉!
linux·c语言·汇编·嵌入式硬件·算法·c
hqxstudying3 小时前
Java创建型模式---单例模式
java·数据结构·设计模式·代码规范