ZOJ 1842 Prime Distance(素数筛选法2次使用)
Prime Distance
Time Limit: 2 Seconds Memory Limit: 65536 KB
The branch of mathematics called number theory is about properties of numbers. One of the areas that has captured the interest of number theoreticians for thousands of years is the question
of primality. A prime number is a number that is has no proper factors (it is only evenly divisible by 1 and itself). The first prime numbers are 2,3,5,7 but they quickly become less frequent. One of the interesting questions is how dense they are in various
ranges. Adjacent primes are two numbers that are both primes, but there are no other prime numbers between the adjacent primes. For example, 2,3 are the only adjacent primes that are also adjacent numbers.
Your program is given 2 numbers: L and U (1 <= L < U <= 2,147,483,647), and you are to find the two adjacent primes C1 and C2 (L <= C1 < C2 <= U) that are closest (i.e. C2-C1 is the minimum).
If there are other pairs that are the same distance apart, use the first pair. You are also to find the two adjacent primes D1 and D2 (L <= D1 < D2 <= U) where D1 and D2 are as distant from each other as possible (again choosing the first pair if there is
a tie).
Input
Each line of input will contain two positive integers, L and U, with L < U. The difference between L and U will not exceed 1,000,000.
Output
For each L and U, the output will either be the statement that there are no adjacent primes (because there are less than two primes between the two given numbers) or a line giving the two pairs of adjacent primes.
Sample Input
2 17
14 17
Sample Output
2,3 are closest, 7,11 are most distant.
There are no adjacent primes.
题目大意
求两个数之间相邻素数值相差最小和最大的数
分析:这道题是学习素数筛法的经典,应用到了区间筛素数。具体思路是先筛出1到sqrt(2147483647)之间的所有素数,然后再通过已经晒好素数筛出给定区间的素数。
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
using namespace std;
const int N=50000;//为什么用到5W?U和L之间的合数,
//质因子不超过O(L^0.5),于是用筛法选出50000内的素数即可,因为50000的平方大于整形上线了
//比如说你只求到1W,但是你有个质数是42347(乱说一个的);那么42347*42347这个数你就不能使他为合数了
//因为你利用的是质数的倍数为合数的筛选法,你没筛选到50000这里
int r[1000000],a[N+100],b[N+100],z; int main()
{
int a0,b0,i,j;
z=0;
memset(a,0,sizeof(a));
for(i=2;i<=N;i++) //1st prime sieve第一次筛选得到5W内的所有质数
if(a[i]==0){
b[++z]=i;//b[z]用来得到a[]中所有的素数z:1->z
for(j=2;i*j<=N;j++) a[i*j]=1;//i的倍数都为1
}
while(~scanf("%d%d",&a0,&b0)){
memset(r,0,sizeof(r));
int t=0,dis,max=-1,min=9999999,m1,m2; for(i=1;i<=z;i++){ //prime sieve again(b[1]到b[z]的素数)
if(b[i]>b0)break;//对于一些小数据来说可以直接就中断掉了
int s,t;
s=(a0-1)/b[i]+1;//if(a0%b[i]==0)a0/b[i]==(a0-1)/b[i]+1;往上取整
t=b0/b[i];//往下取整 这样取整的目的是为了让0<=j*b[i]-a0<=b0-a0 不然其他取整会超出范围
for(j=s;j<=t;j++)//j的取值一定是>=1 如果是==1的情况 说明(a0-1)<b[i]即a0<=b[i]
if(j>1) r[j*b[i]-a0]=1;//r[]==1表示为合数(为了限定范围在0<->(b0-a0),其实意思是j*b[i]是一个合数)
}//j!=1 举 1,20 b[i]=7 这时s=1,t=2 if(j==1)可以 则[1*7-1]=1 正如上面所说后面还要a0=1 难道说7是合数?
//总的来说,j==1时 b[i]是质数 j*b[i]-a0+a0肯定也是质数 int k=-1;
for(i=0;i<=b0-a0;i++)
if(!r[i]){//如果r[i]==0 (不是合数的情况)
if(k!=-1){//第一个是不能计的至少要两个
dis=i-k;//与前一次的差
if(dis>max){
max=dis;
m1=i+a0;//m1表示的是最大值
}
if(dis<min){
min=dis;
m2=i+a0;//m2表示的是第二小
} }
if(i+a0!=1) k=i;//第一次是这个用来下一次的使用
// k=i;//这样是错的 注意当a0=1的时候r[0]是一定为0的但是[举[1,2]]
//如果这边没注意让 k=0的话,max=i-0,mi=i+a0(1);显然当元素中只有一个素数的时候是不能输出结果 但是这样却有结果
} //if(max<0)说明没有进行过任何比较
if(max<0) printf("There are no adjacent primes.\n");
else printf("%d,%d are closest, %d,%d are most distant.\n",m2-min,m2,m1-max,m1);
}
return 0;
}
版权声明:本文为博主原创文章,未经博主允许不得转载。
ZOJ 1842 Prime Distance(素数筛选法2次使用)的更多相关文章
- POJ2689 - Prime Distance(素数筛选)
题目大意 给定两个数L和U,要求你求出在区间[L, U] 内所有素数中,相邻两个素数差值最小的两个素数C1和C2以及相邻两个素数差值最大的两个素数D1和D2,并且L-U<1,000,000 题解 ...
- zoj 1842 Prime Distance
// 数论题,增强的筛法,回想素数筛法 // 只要筛到最大数的开方,剩下的就是素数 // 于是这里,开一个 sqrt(2^31) 大约 65536 的素数表,然后 // 对于每个 L~U 的区间,筛掉 ...
- POJ 2689 Prime Distance (素数筛选法,大区间筛选)
题意:给出一个区间[L,U],找出区间里相邻的距离最近的两个素数和距离最远的两个素数. 用素数筛选法.所有小于U的数,如果是合数,必定是某个因子(2到sqrt(U)间的素数)的倍数.由于sqrt(U) ...
- PAT甲题题解-1059. Prime Factors (25)-素数筛选法
用素数筛选法即可. 范围long int,其实大小范围和int一样,一开始以为是指long long,想这就麻烦了该怎么弄. 而现在其实就是int的范围,那难度档次就不一样了,瞬间变成水题一枚,因为i ...
- 素数筛选法(prime seive)
素数筛选法比较有名的,较常用的是Sieve of Eratosthenes,为古希腊数学家埃拉托色尼(Eratosthenes 274B.C.-194B.C.)提出的一种筛选法.详细步骤及图示讲解,还 ...
- POJ 3978 Primes(素数筛选法)
题目 简单的计算A,B之间有多少个素数 只是测试数据有是负的 //AC //A和B之间有多少个素数 //数据可能有负的!!! #include<string.h> #include< ...
- LightOJ 1259 Goldbach`s Conjecture (哥德巴赫猜想 + 素数筛选法)
http://lightoj.com/volume_showproblem.php?problem=1259 题目大意:给你一个数n,这个数能分成两个素数a.b,n = a + b且a<=b,问 ...
- poj 2262 Goldbach's Conjecture(素数筛选法)
http://poj.org/problem?id=2262 Goldbach's Conjecture Time Limit: 1000MS Memory Limit: 65536K Total ...
- HDU_2136——最大质因数,素数筛选法
Problem Description Everybody knows any number can be combined by the prime number. Now, your task i ...
随机推荐
- 面试被问到IIC,总结。
Linux3.5内核中,IIC. i2c_add_driver i2c_register_driver a. at24cxx_driver放入i2c_bus_type的drv链表 并且从dev链表里取 ...
- drag element
<div id="logDiv" draggable="true" style="border: 2px dotted red; width: ...
- [BZOJ1185][HNOI2007]最小矩形覆盖-[凸包+旋转卡壳]
Description 传送门 Solution 感性理解一下,最小矩形一定是由一条边和凸包上的边重合的. 然后它就是模板题了..然而真的好难调,小于大于动不动就打错. Code #include&l ...
- c++ 创建单项链表
建立单向链表 头指针Head 插入结点 //建立头结点 Head Head=p= malloc(sizeof( struct stu_data)); // memset(stu,,sizeof( st ...
- 从原理到代码:大牛教你如何用 TensorFlow 亲手搭建一套图像识别模块 | AI 研习社
从原理到代码:大牛教你如何用 TensorFlow 亲手搭建一套图像识别模块 | AI 研习社 PPT链接: https://pan.baidu.com/s/1i5Jrr1N 视频链接: https: ...
- Java 中的正则(Pattern)
/**String 中 replaceAll(),matches(),split() 等方法,都是调用Pattern中的方法.学习了,瞬间觉得Pattern强大了 public String repl ...
- StringUtils工具类用法
/*1.字符串以prefix开始*/ StringUtils.startsWith("sssdf","");//结果是:true StringUtils.sta ...
- IIS解决上传文件大小限制
目的:通过配置文件和IIS来解决服务器对上传文件大小的限制 1:修改配置文件(默认为4M 值的大小根据自己情况进行修改) <httpRuntime maxRequestLength=" ...
- VirtualBox主机和虚拟机互相通信
默认情况下VirtualBox虚拟机网络设置为网络地址转换,虚拟机中的地址一般是10.0.2.x,虚拟机中访问主机只需要访问默认网关地址即可,但是主机访问虚拟机就需要增加一些配置了,方法有以下几种: ...
- linux安装PHP-memcache-redis扩展
1.php memcache 扩展 http://pecl.php.net/package/memcache/3.0.8 下载文件源码 #tar zxvf memcache-3.0.8.tar#/us ...