洛谷题解 P1217 【[USACO1.5]回文质数 Prime Palindromes】

本文介绍了如何解决USACO1.5题目的【回文质数】问题。通过揭示回文数的特性,提出通过枚举回文数前半部分来构造并检查是否为素数的方法,提高了算法效率。使用递归函数在数组中填充数,并在完成前半部分后反转复制到后半段,确保回文性。最后,检查生成的数是否为素数,按字典序输出。
摘要由CSDN通过智能技术生成

模拟构造回文素数

这道题本来是随便打表A掉的,但这实在不符合我的水准,于是想出了这份代码。
打表过的要脸么


刚拿到这题,首先想到暴力枚举。但看到数据规模似乎并不是很友好,只得作罢。。。

这时发现题目所述回文数一条神奇的性质:**当确定回文数的前半段时,该回文数的后半段也随之确定。**于是顿时想到可以通过枚举回文数的前半部分,生成其后半部分,然后判断它是否为素数,最后输出。

在枚举前半段回文数时,利用递归函数在fig数组中依次填数。当枚举完前半段后,再将后半段回文数补充完整。模拟过程如下图:

模拟回文数

可以发现,无论要生成的回文数长度为多少,fig[(size+1)/2] 中总填入前半段回文数的最后一个数。当递归函数填至下一个格子中时,便可将前半段回文数反转后复制到后半段数组中。代码实现如下:

void DFS(int size,int now)
{
    if(now<=(size+1)/2)
        for(register int i=0;i<=9;++i)
        {
            if(now==1&&(i==0||i%2==0)) continue;//fig[1]中的数不能为0或偶数
            fig[now]=i;
            DFS(size,now+1);
            if(flag==false) return;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值