开始看第一眼题就觉得问题会在超时上,果然写了个小代码运行到test 9时超时了

#include <stdio.h>
#include <math.h> int isprime(int M)
{
int i;
float N = M;
for(i = ; i <= sqrt(N); i++)
{
if(M % i == )
return ;
}
return ;
} int ispalindromes(int N)
{
char numc[] = {};
int l;
char *p, *q;
for(l = ; N != ; l++)
{
numc[l] = N % + '';
N = N / ;
}
l--;
for(p = numc, q = numc + l; p < q; p++, q--)
{
if(*p != *q)
return ;
}
return ;
} int main()
{
FILE *in, *out;
in = fopen("pprime.in", "r");
out = fopen("pprime.out", "w"); int a, b;
fscanf(in, "%d %d", &a, &b); int i, j;
for(i = a; i <= b; i++)
{
if(ispalindromes(i) && isprime(i))
{
fprintf(out, "%d\n", i);
}
} return ;
}

----------------------------------------------

化简途径是直接生成回文 我的代码边界处理的有点乱 不过AC了 确实速度比一个个判断快很多 大概快个100倍吧

每次回文生成的前半段都是 10 — 99  100 - 999 1000 - 9999 这样的情况,要分奇偶数处理

#include <stdio.h>
#include <math.h> int isprime(int M)
{
int i;
float N = M;
for(i = ; i <= sqrt(N); i++)
{
if(M % i == )
return ;
}
return ;
}
int main()
{
FILE *in, *out;
in = fopen("pprime.in", "r");
out = fopen("pprime.out", "w"); int a, b;
int i, j, k;
int l, s;
int bb, aa;
fscanf(in, "%d %d", &a, &b); bb = b;
aa = a; for(l = ; bb != ; l++)
{
bb = bb / ;
}
for(s = ; aa != ; s++)
{
aa = aa / ;
}
for(i = s; i <= l; i++)
{
int small, large; //回文产生中,不重复部分最大最小值 int ll = i/ + i % ; //回文不重复长度
if(i == s) //最小边界
{
small = a;
for(j = ; j < i - ll; j++)
{
small = small / ;
}
}
else
{
for(small = , j = ; j < ll; j++)
{
small = small * ;
}
}
for(large = , j = ; j <= ll; j++)
{
large = large * ;
}
large--; for(j = small; j <= large; j++)
{
int lll;
int pal;
int num[] = {};
int jj = j;
for(k = ; jj != ; k++)
{
num[k] = jj % ;
jj = jj / ;
}
lll = k;
pal = j;
if(i % == )
{
for(k = ; k < lll; k++)
{
pal = pal * + num[k];
}
if(pal > b) return ; //不能超过最大值
if(isprime(pal))
{
fprintf(out, "%d\n", pal);
} }
else
{
for(k = ; k < lll; k++)
{
pal = pal * + num[k];
}
if(pal > b) return ;
if(isprime(pal))
{
fprintf(out, "%d\n", pal);
}
}
}
} return ;
}

看了下答案,思路差不多,但是比我的清楚很多。学习到的技巧:

素数判断:

int
isprime(long n)
{
long i; if(n == ) // 2单独处理
return ; if(n% == )
return ; for(i=; i*i <= n; i+=) // i * i <= n 可以避免sqrt
if(n%i == )
return ; return ;
}

atol()函数 可以将字符串转为整数

【USACO】pprime的更多相关文章

  1. POJ 1986 Distance Queries / UESTC 256 Distance Queries / CJOJ 1129 【USACO】距离咨询(最近公共祖先)

    POJ 1986 Distance Queries / UESTC 256 Distance Queries / CJOJ 1129 [USACO]距离咨询(最近公共祖先) Description F ...

  2. 1642: 【USACO】Payback(还债)

    1642: [USACO]Payback(还债) 时间限制: 1 Sec 内存限制: 64 MB 提交: 190 解决: 95 [提交] [状态] [讨论版] [命题人:外部导入] 题目描述 &quo ...

  3. 1519: 【USACO】超级书架

    1519: [USACO]超级书架 时间限制: 1 Sec 内存限制: 64 MB 提交: 1735 解决: 891 [提交] [状态] [讨论版] [命题人:外部导入] 题目描述 Farmer Jo ...

  4. Java实现【USACO】1.1.2 贪婪的礼物送礼者 Greedy Gift Givers

    [USACO]1.1.2 贪婪的礼物送礼者 Greedy Gift Givers 题目描述 对于一群要互送礼物的朋友,你要确定每个人送出的礼物比收到的多多少(and vice versa for th ...

  5. 【CPLUSOJ】【USACO】【差分约束】排队(layout)

    [题目描述] Robin喜欢将他的奶牛们排成一队.假设他有N头奶牛,编号为1至N.这些奶牛按照编号大小排列,并且由于它们都很想早点吃饭,于是就很可能出现多头奶牛挤在同一位置的情况(也就是说,如果我们认 ...

  6. 【USACO】Dining

    [题目链接] [JZXX]点击打开链接 [caioj]点击打开链接 [算法] 拆点+网络流 [代码] #include<bits/stdc++.h> using namespace std ...

  7. 【USACO】Optimal Milking

    题目链接 :        [POJ]点击打开链接        [caioj]点击打开链接 算法 : 1:跑一遍弗洛伊德,求出点与点之间的最短路径 2:二分答案,二分”最大值最小“ 3.1:建边,将 ...

  8. 【USACO】 Balanced Photo

    [题目链接] 点击打开链接 [算法] 树状数组 [代码] #include<bits/stdc++.h> using namespace std; int i,N,ans,l1,l2; ] ...

  9. 【USACO】 Balanced Lineup

    [题目链接] 点击打开链接 [算法] 这是一道经典的最值查询(RMQ)问题. 我们首先想到线段树.但有没有更快的方法呢?对于这类问题,我们可以用ST表(稀疏表)算法求解. 稀疏表算法.其实也是一种动态 ...

随机推荐

  1. MySQL tips (日期时间操作/concat 等)

    1.  Query结尾要加一个分号: 2.  数据库和表 SHOW DATABASES;    USE YOUR_DB; SHOW TABLES; SHOW COLUMNS FROM study或者D ...

  2. BZOJ-1927 星际竞速 最小费用最大流+拆点+不坑建图

    1927: [Sdoi2010]星际竞速 Time Limit: 20 Sec Memory Limit: 259 MB Submit: 1593 Solved: 967 [Submit][Statu ...

  3. asp.net 实现在线打印功能,jQuery打印插件PrintArea实现自动分页

    使用的组件:jQuery打印插件PrintArea,有兴趣的可以研究一下. 使用方法略过,这里将介绍如何实现打印多页是可以分页. 现在提供两种方法思路: 1.根据特定的打印机型号和使用的纸张类型,然后 ...

  4. TCP/IP详解 学习三

    网际协议 ip Ip 是不可靠和无连接的 ip首部 4个字节的 32 bit值以下面的次序传输:首先是 0-7 bit,其次 8-15 bit,然后 1 6-23 bit,最后是 24~31 bit. ...

  5. java基本类型转换规则

    自动类型转换,也称隐式类型转换,是指不需要书写代码,由系统自动完成的类型转换.由于实际开发中这样的类型转换很多,所以Java语言在设计时,没有为该操作设计语法,而是由JVM自动完成. 具体规则为: b ...

  6. SPOJ Play on Words

    传送门 WORDS1 - Play on Words #graph-theory #euler-circuit Some of the secret doors contain a very inte ...

  7. UVa 12505 Searching in sqrt(n)

    传送门 一开始在vjudge上看到这题时,标的来源是CSU 1120,第八届湖南省赛D题“平方根大搜索”.今天交题时CSU突然跪了,后来查了一下看哪家OJ还挂了这道题,竟然发现这题是出自UVA的,而且 ...

  8. 静态内部类和Lazy<T>优雅实现单例

    public class Singleton { private Singleton() { } public static Singleton GetInstance() { return Conc ...

  9. linux桌面应用开发之折腾

    1 起因 需要开发一个wifi定位的应用,最先在android下搞,后来因为多网卡的原因要换平台,经历了windows,最终选择用kaili linux.debian系的linux,开发桌面应用怎么办 ...

  10. ECSHOP管理员密码忘记了怎么办?

    ECSHOP管理员密码忘记了怎么办? ECSHOP教程/ ecshop教程网(www.ecshop119.com) 2013-09-06   不小心在后台把管理员全部给清空了,闹的网站都无法登陆了?有 ...