POJ2689:Prime Distance——题解
http://poj.org/problem?id=2689
题目大意,给不超过int的l,r,其中r-l+1<=1000000,筛出其中的素数,并且求出相邻素数差值最大和最小的一对。
——————————————————
显然这是一道筛出l和r之间素数的裸题。
我们发现对于区间里的一个合数,其最大质因子不会超过50000(不然50000平方就大于2147483647)
秉承着正难则反的思想,筛1-50000素数,然后用一种很神奇的方法判断掉区间里的合数,统计素数即可。
判断方法:
首先我们将每个素数(记为su)平方得到t,一定是合数。
如果发现其<l。
我们就可以t=l/su*su,得到的也一定是合数。
如果此时仍然<l,我们为t+=su,得到的还是合数。
当然如果超了r那就continue;
然后对于t打标记。
然后不断地t+=su直到超r为止。
可以发现一定能够筛全合数。
简略证明:
不断地加相当于乘。
所以实际上我们在做的就是(例如su=2),就是2*2,2*3,2*4,2*5……这些全是合数。
而且因为起点是平方,所以避免了3*2这样的重复产生,所以更加的快捷。
- #include<cstdio>
- #include<cstring>
- #include<iostream>
- #include<cmath>
- #include<map>
- #include<algorithm>
- using namespace std;
- const int INF=;
- int su[]={};
- bool he[]={};
- int cnt=;
- bool vis[]={};
- void Euler(int n){
- for(int i=;i<=n;i++){
- if(he[i]==){
- cnt++;
- su[cnt]=i;
- }
- for(int j=;j<=cnt&&i*su[j]<=n;j++){
- he[su[j]*i]=;
- if(i%su[j]==)break;
- }
- }
- return;
- }
- int main(){
- Euler();
- int l,r;
- while(scanf("%d%d",&l,&r)!=EOF){
- memset(vis,,sizeof(vis));
- int ans=;
- for(int i=;i<=cnt&&su[i]<=sqrt(r);i++){
- //t接下来无论怎么变都是合数
- int t=su[i]*su[i];
- if(t<l)t=l/su[i]*su[i];//t太小的时候就得这样让它变大点
- if(t<l){
- if(t<=r-su[i]){
- t+=su[i];
- }else continue;
- }
- while(t<=r){
- vis[t-l]=;
- if(t==su[i])vis[t-l]=;//压缩空间
- if(t<=r-su[i])t+=su[i];
- else break;
- }
- }
- if(l==)vis[]=;
- int p=-;
- int x1,y1,x2,y2,ans1=-,ans2=INF;
- for(int i=;i<=r-l;i++){
- if(!vis[i]){
- if(p==-){p=i;continue;}
- if(ans1<i-p){ans1=i-p;x1=p+l;y1=i+l;}
- if(ans2>i-p){ans2=i-p;x2=p+l;y2=i+l;}
- p=i;
- }
- }
- if(ans1==-)cout<<"There are no adjacent primes."<<endl;
- else cout<<x2<<","<<y2<<" are closest, "<<x1<<","<<y1<<" are most distant."<<endl;
- }
- return ;
- }
POJ2689:Prime Distance——题解的更多相关文章
- poj2689 Prime Distance题解报告
题目戳这里 [题目大意] 给定一个区间[L,R],求区间内的质数相邻两个距离最大和最小的. [思路分析] 其实很简单呀,很明显可以看出来是数论题,有关于质数的知识. 要注意一下的就是L和R的数据范围都 ...
- POJ2689 Prime Distance(数论:素数筛选模板)
题目链接:传送门 题目: Prime Distance Time Limit: 1000MS Memory Limit: 65536K Total Submissions: Accepted: Des ...
- POJ-2689 Prime Distance (两重筛素数,区间平移)
Prime Distance Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 13961 Accepted: 3725 D ...
- 解题报告:poj2689 Prime Distance
2017-10-03 11:29:20 writer:pprp 来源:kuangbin模板 从已经筛选好的素数中筛选出规定区间的素数 /* *prime DIstance *给出一个区间[L,U],找 ...
- POJ-2689 Prime Distance,区间素数筛法
Prime Distance 只会埃氏筛法的弱鸡今天读了读挑战程序设计120页,明白了求小区间内素数的方 ...
- POJ2689 - Prime Distance(素数筛选)
题目大意 给定两个数L和U,要求你求出在区间[L, U] 内所有素数中,相邻两个素数差值最小的两个素数C1和C2以及相邻两个素数差值最大的两个素数D1和D2,并且L-U<1,000,000 题解 ...
- POJ2689:Prime Distance(大数区间素数筛)
The branch of mathematics called number theory is about properties of numbers. One of the areas that ...
- POJ2689 Prime Distance 质数筛选
题目大意 求区间[L, R]中距离最大和最小的两对相邻质数.R<2^31, R-L<1e6. 总体思路 本题数据很大.求sqrt(R)的所有质数,用这些质数乘以j, j+1, j+2... ...
- poj2689 Prime Distance(素数区间筛法)
题目链接:http://poj.org/problem?id=2689 题目大意:输入两个数L和U(1<=L<U<=2 147 483 647),要找出两个相邻素数C1和C2(L&l ...
随机推荐
- 怎么设计好移动APP测试用例
软件测试工作中我们需要不断的储备和总结自己的知识和经验,怎么设计好移动APP测试用例?如:手机.平板.智能设备,并在特定网络环境下. 我们需要关注的功能点,容易出错的位置,这将对我们整个测试过程起着至 ...
- Linux命令应用大词典-第45章 服务器配置
45.1 ssh-agent:存储用于公钥验证的私钥 45.2 ssh-add:添加RSA或DSA身份的认证代理 45.3 ssh-keyscan:收集主机公钥 45.4 sshd:运行sshd守护进 ...
- TPO-13 C2 How to use language lab
TPO-13 C2 How to use language lab 第 1 段 1.Listen to a conversation between a student and the languag ...
- Python全栈 正则表达式(re模块正则接口全方位详解)
re模块是Python的标准库模块 模块正则接口的整体模式 re.compile 返回regetx对象 finditer fullmatch match search 返回 match对象 match ...
- 哈希表 -数据结构(C语言实现)
读数据结构与算法分析 哈希表 一种用于以常数平均时间执行插入.删除和查找操作的数据结构. 但是是无序的 一般想法 通常为一个包含关键字的具有固定大小的数组 每个关键字通过散列函数映射到数组中 冲突:两 ...
- (转) GEM透视阴影贴图
转载:小道 透视阴影贴图(Perspective Shadow Maps, PSMs)是由Stamminger和Drettakis在 SIGGRAPH 2002上提出的一种阴影贴图(Shadow Ma ...
- 浙江天搜科技落棋人工智能,加速AI产业布局
8月31日,2018年IFA大展在德国柏林正式开幕.IFA是全球三大消费电子展之一,在世界范围内久负盛名,被誉为“未来科技风向标”.在这个万众瞩目的展会上,号称“给智能世界铺上云的跑道,装上智能发动机 ...
- Python3 小工具-ICMP扫描
from scapy.all import * import optparse import threading import os def scan(ipt): pkt=IP(dst=ipt)/IC ...
- 每周psp-第五周
PSP表格: 类别 任务 开始时间 结束时间 中断时间 delta时间 开会 scrum立会 10.13下午6:04 10.13下午6:34 0 30 开会 scrum立会 10.14下午6:02 1 ...
- 软件工程第四周作业-PSP
psp表格 类别 内容 开始时间 结束时间 中断时间 delta时间 学习 学习C# 10.6下午7:00 10.6下午8:00 - 60min 写代码 写主函数以及一些小的方法 10.7下午2:00 ...