Prime Palindromes

The number 151 is a prime palindrome because it is both a prime number and a palindrome (it is the same number when read forward as backward). Write a program that finds all prime palindromes in the range of two supplied numbers a and b (5 <= a < b <= 100,000,000); both a and b are considered to be within the range .

PROGRAM NAME: pprime

INPUT FORMAT

Line 1: Two integers, a and b

SAMPLE INPUT (file pprime.in)

5 500

OUTPUT FORMAT

The list of palindromic primes in numerical order, one per line.

SAMPLE OUTPUT (file pprime.out)

5
7
11
101
131
151
181
191
313
353
373
383 ——————————————————————题解
就是枚举回文数然后筛,写了一个logn的筛法(Miller Rabin),结果乘法没开longlong导致wa了一次
枚举素数我手敲了八个循环……后来ac看analysis……只要10-9999然后翻转就行orz我感觉自己真是个辣鸡
而且这位小哥以神一般的数学直觉便判断出任何二倍长的回文数一定是11的倍数,那么我们就不用考虑偶数个的了。小学数学老师你还要我吗要我吗……
这轻描淡写的一句话顶上了我30++行代码orz
那个版权不敢盗,所以不粘别人代码,贴上我易读的代码……以及写的很丑的Miller Rabin(check函数)
 /*
PROB: pprime
LANG: C++
ID: jiaqi si
*/
#include <iostream>
#include <string.h>
#include <cstdlib>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <vector>
#include <ctime>
#define ivory
#define mo 1000000007
#define siji(i,x,y) for(int i=(x);i<=(y);i++)
#define gongzi(j,x,y) for(int j=(x);j>=(y);j--)
#define xiaosiji(i,x,y) for(int i=(x);i<(y);i++)
#define sigongzi(j,x,y) for(int j=(x);j>(y);j--)
#define pii pair<int,int>
#define fi first
#define se second
#define mo 1000000007
using namespace std;
int ans[],cnt;
int a,b;
int mpow(int c,int d,int k) {
if(d==) {
return c%k;
}
else {
int tmp=mpow(c,d/,k)%k;
if(d&) {
return 1LL*tmp*tmp%k*c%k;
}
else {
return 1LL*tmp*tmp%k;
}
}
}
bool _check(int v,int s,int k) {
if(v==) return true;
siji(i,,s) {
if(1LL*v*v%k==) {
if(v%k==k-){return true;}
else return false;
}
v=1LL*v*v%k;
}
return false;
}
bool check(int k) {
int tmp=k-;
int s=;
while(tmp%(<<s)==) ++s;
--s;
int d=tmp/(<<s);
int tmp1=mpow(,d,k);
int tmp2=mpow(,d,k);
int tmp3=mpow(,d,k);
bool f=;
if(!_check(tmp1,s,k)) {f=;}
else if(k> && (!_check(tmp2,s,k))) {f=;}
else if(k> && (!_check(tmp3,s,k))) {f=;}
return f;
}
int binary(int k){
int l=,r=cnt;
while(l<r) {
int mid=(l+r+)>>;
if(ans[mid]>=k) r=mid-;
else l=mid;
}
return l;
}
int main() {
#ifdef ivory
freopen("pprime.in","r",stdin);
freopen("pprime.out","w",stdout);
#else
//freopen("f1.in","r",stdin);
#endif
ans[++cnt]=;
siji(i,,) {
if(i%!= && check(i)) ans[++cnt]=i;
}
siji(i,,) {
if(i%==)continue;
int tmp=i*+i;
if(check(tmp)) ans[++cnt]=tmp;
}
siji(i,,) {
if(i%==) continue;
siji(j,,) {
int tmp=i*+j*+i;
if(check(tmp)) ans[++cnt]=tmp;
}
}
siji(i,,) {
if(i%==) continue;
siji(j,,) {
int tmp=i*+j*+j*+i;
if(check(tmp)) ans[++cnt]=tmp;
}
}
siji(i,,) {
if(i%==) continue;
siji(j,,) {
siji(k,,) {
int tmp=i*+j*+k*+j*+i;
if(check(tmp)) ans[++cnt]=tmp;
}
}
}
siji(i,,) {
if(i%==) continue;
siji(j,,) {
siji(k,,) {
int tmp=i*+j*+k*+k*+j*+i;
if(check(tmp)) ans[++cnt]=tmp;
}
}
}
siji(i,,) {
if(i%==) continue;
siji(j,,) {
siji(k,,) {
siji(h,,) {
int tmp=i*+j*+k*+h*+k*+j*+i;
if(check(tmp)) ans[++cnt]=tmp;
} }
}
}
siji(i,,) {
if(i%==) continue;
siji(j,,) {
siji(k,,) {
siji(h,,) {
int tmp=i*+j*+k*+h*+h*+k*+j*+i;
if(check(tmp)) ans[++cnt]=tmp;
}
}
}
}
scanf("%d%d",&a,&b);
int il=binary(a);
int ir=binary(b);
if(ans[ir+]==b) ir++;
siji(i,il+,ir) {
printf("%d\n",ans[i]);
}
}

 

USACO 1.5 Prime Palindromes的更多相关文章

  1. USACO Section1.5 Prime Palindromes 解题报告

    pprime解题报告 —— icedream61 博客园(转载请注明出处)--------------------------------------------------------------- ...

  2. P1217 [USACO1.5]回文质数 Prime Palindromes(求100000000内的回文素数)

    P1217 [USACO1.5]回文质数 Prime Palindromes 题目描述 因为151既是一个质数又是一个回文数(从左到右和从右到左是看一样的),所以 151 是回文质数. 写一个程序来找 ...

  3. 洛谷 P1217 [USACO1.5]回文质数 Prime Palindromes

    P1217 [USACO1.5]回文质数 Prime Palindromes 题目描述 因为151既是一个质数又是一个回文数(从左到右和从右到左是看一样的),所以 151 是回文质数. 写一个程序来找 ...

  4. luogu P1217 [USACO1.5]回文质数 Prime Palindromes x

    P1217 [USACO1.5]回文质数 Prime Palindromes 题目描述 因为151既是一个质数又是一个回文数(从左到右和从右到左是看一样的),所以 151 是回文质数. 写一个程序来找 ...

  5. 4190. Prime Palindromes 一亿以内的质数回文数

    Description The number 151 is a prime palindrome because it is both a prime number and a palindrome ...

  6. <Sicily>Prime Palindromes

    一.题目描述 The number 151 is a prime palindrome because it is both a prime number and a palindrome (it i ...

  7. USACO Prime Palindromes 构造回文数

    这道题目一点也不卡素数的判断 就是朴素的sqrt(n) 也不卡 所以~放心的用吧. 构造回文的时候看了HINT 其中是这么写的: Generate palindromes by combining d ...

  8. 【USACO 1.5】Prime Palindromes

    /* TASK: pprime LANG: C++ SOLVE: 枚举数的长度,dfs出对称的数,判断是否在范围内,是否是素数 原来想着枚举每个范围里的数,但是显然超时,范围最大是10^9. 对称的数 ...

  9. USACO Section 1.5 Prime Palindromes 解题报告

    题目 题目描述 题目就是给定一个区间[a,b]((5 <= a < b <= 100,000,000)),我们需要找到这个区间内所有既是回文串又是素数的数字. 输入样例 5 500 ...

随机推荐

  1. C#Windows Form简易计算器实现(中)

    昨天花了一天的时间弄计算器.也算是做出来了,还是简易的(怀疑猿生!!).在此先感谢昨天被我骚扰的朋友. 先贴一张界面看看 其实健壮性还是挺差的,用户体验也是极差的.比如说用户输入了不合理运算式子,我就 ...

  2. JSON对象和字符串的转换

    JSON.parse()和JSON.stringify()   1.parse 用于从一个字符串中解析出json 对象.例如 var str='{"name":"cpf& ...

  3. IntelliJ IDEA 设置代码提示或自动补全的快捷键 (附IntelliJ IDEA常用快捷键)

    修改方法如下: 点击 文件菜单(File) –> 点击 设置(Settings- Ctrl+Alt+S), –> 打开设置对话框. 在左侧的导航框中点击 KeyMap. 接着在右边的树型框 ...

  4. jQuery事件命名空间

    先看一些代码: 也可以用bind进行事件绑定.我们看到上面的代码,我们可以在事件后面,以点号,加我们的名字,就是事件命名空间.所谓事件命名空间,就是事件类型后面以点语法附加一个别名,以便引用事件,如& ...

  5. 我是这样使用template.js来异步渲染数据的

    总监的代码用的是define+module.exports,为了效率先没去了解那一块,在github上找了一款功能单一的template.js来使用 https://github.com/yanhai ...

  6. Eclipse/MyEclipse 安裝後應該更改的設置

    基本上都通過 Window -> Preferences 進行設置: Java 保存自動格式化: Java:Java -> Editor -> Save Actions,選中 Per ...

  7. fpga串口通信

    ---恢复内容开始--- 1.波特率的计算公式:9600bps 是指每秒可以传输9600位 则一位需要的时间为1/9600 约等于0.000104 开发板晶振大小为50M则传输一位需要的时间为 0.0 ...

  8. CentOS网络接口配置文件ifcfg-eth详解

    ======CentOS网络接口配置文件ifcfg-eth详解====== 文件 /etc/sysconfig/network-scripts/ifcfg-eth0在/etc/sysconfig/ne ...

  9. 自动生成 Makefile (automake/autoconf 入门)

    作为Linux 下的程序开发人员,大家一定都遇到过Makefile ,用make 命令来编译自己写的程序确实是很方便.一般情况下,大家都是手工写一个简单Makefile ,如果要想写出一个符合自由软件 ...

  10. PAT乙级1034. 有理数四则运算(20)

    本题要求编写程序,计算2个有理数的和.差.积.商. 输入格式: 输入在一行中按照“a1/b1 a2/b2”的格式给出两个分数形式的有理数,其中分子和分母全是整型范围内的整数,负号只可能出现在分子前,分 ...