【USACO】pprime
开始看第一眼题就觉得问题会在超时上,果然写了个小代码运行到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的更多相关文章
- POJ 1986 Distance Queries / UESTC 256 Distance Queries / CJOJ 1129 【USACO】距离咨询(最近公共祖先)
POJ 1986 Distance Queries / UESTC 256 Distance Queries / CJOJ 1129 [USACO]距离咨询(最近公共祖先) Description F ...
- 1642: 【USACO】Payback(还债)
1642: [USACO]Payback(还债) 时间限制: 1 Sec 内存限制: 64 MB 提交: 190 解决: 95 [提交] [状态] [讨论版] [命题人:外部导入] 题目描述 &quo ...
- 1519: 【USACO】超级书架
1519: [USACO]超级书架 时间限制: 1 Sec 内存限制: 64 MB 提交: 1735 解决: 891 [提交] [状态] [讨论版] [命题人:外部导入] 题目描述 Farmer Jo ...
- Java实现【USACO】1.1.2 贪婪的礼物送礼者 Greedy Gift Givers
[USACO]1.1.2 贪婪的礼物送礼者 Greedy Gift Givers 题目描述 对于一群要互送礼物的朋友,你要确定每个人送出的礼物比收到的多多少(and vice versa for th ...
- 【CPLUSOJ】【USACO】【差分约束】排队(layout)
[题目描述] Robin喜欢将他的奶牛们排成一队.假设他有N头奶牛,编号为1至N.这些奶牛按照编号大小排列,并且由于它们都很想早点吃饭,于是就很可能出现多头奶牛挤在同一位置的情况(也就是说,如果我们认 ...
- 【USACO】Dining
[题目链接] [JZXX]点击打开链接 [caioj]点击打开链接 [算法] 拆点+网络流 [代码] #include<bits/stdc++.h> using namespace std ...
- 【USACO】Optimal Milking
题目链接 : [POJ]点击打开链接 [caioj]点击打开链接 算法 : 1:跑一遍弗洛伊德,求出点与点之间的最短路径 2:二分答案,二分”最大值最小“ 3.1:建边,将 ...
- 【USACO】 Balanced Photo
[题目链接] 点击打开链接 [算法] 树状数组 [代码] #include<bits/stdc++.h> using namespace std; int i,N,ans,l1,l2; ] ...
- 【USACO】 Balanced Lineup
[题目链接] 点击打开链接 [算法] 这是一道经典的最值查询(RMQ)问题. 我们首先想到线段树.但有没有更快的方法呢?对于这类问题,我们可以用ST表(稀疏表)算法求解. 稀疏表算法.其实也是一种动态 ...
随机推荐
- Xcode 6以上版本如何创建一个空的工程(Empty Application)
Xcode 6 正式版里面没有Empty Application这个模板,这对于习惯了纯代码编写UI界面的程序员来说很不习惯. 有高手给出了一个解决方法是,把Xcode 6 beta版里面的模板复制过 ...
- Record is locked by another user --Oracle行锁解锁
Oracle修改表中记录时出现record is locked by another user的问题 在操作表时没有commit,导致表被锁,只要执行下面两行语句,就可以了将行锁解锁了. 1. ...
- eclipse中建python项目并运行
1. Help → Install New Software 2.Enter http://pydev.org/updates 3.点击Click "Next" and " ...
- 行为Behavior的使用
原文地址:http://www.it610.com/article/4918541.htm 行为就是继承yii\base\behavior,可以绑定到任意yii\base\compent实例上,然后这 ...
- ASP.NET MVC 开启AJAX跨域请求
<system.webServer> <httpProtocol> <customHeaders> <add name="Access-Contro ...
- 用java做的免费投票器/软件/工具 可定制
免费投票器/软件/工具 可定制 下载地址: http://pan.baidu.com/s/1c0je5HY 界面预览:
- 如何查看ubuntu下显卡驱动是否已经成功安装
首先得安装mesa-utils,在终端输入命令:sudo apt-get install mesa-utils然后再运行命令:glxinfo | grep rendering如果结果是“yes”,证明 ...
- 唐巧的iOS技术博客选摘
1. 那些被遗漏的objective-c保留字:http://blog.devtang.com/blog/2013/04/29/the-missing-objc-keywords/ 2. 使用cr ...
- HDOJ 2063 过山车
过山车 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...
- 微信二维码占座 书本水杯板砖都out了
还在用书本.水杯.坐垫.板砖.铁链占座?你OUT了.新学期开学,重大图书馆开通了扫二维码占座功能,同学们只需扫一扫贴在桌子上的二维码,就可以占座.不过,占座有时间限制,如果没有在规定的时间内返回,系统 ...