zoukankan      html  css  js  c++  java
  • [POJ 2689] Prime Distance

    Description

    给定两个整数 (L,R;(1leq Lleq Rleq 2^{31},R-Lleq 10^6)) ,求闭区间 ([L,R]) 中相邻两个数最大的差是多少,输出这些质数。

    Solution

    任何一个合数 (N) 必定包含一个不超过 (sqrt N) 的质因子。

    所以,我们只需要用筛法求出 (2-sqrt N) 之间的所有质数。对于每个质数 (p) ,把 ([L,R]) 中能被 (p) 整除的数标记。

    最终所有未被标记的数就是 ([L,R]) 中的质数,对相邻的质数两两比较,找出差最大的即可。

    还有一个要注意的是这题 (L,R) 范围太大,数组开不小,所以对于每个询问,都要加一个偏移量来进行标记和判断。

    Code

    #include<cmath>
    #include<cstdio>
    #include<cstring>
    #define N 52005
    
    int l,r;
    int sum[1000005];
    bool is_prime[N+10];
    int prime[N],primecnt;
    
    void init(int n){
    	is_prime[1]=1;
    	for(int i=2;i<=N;i++){
    		if(!is_prime[i])
    			prime[++primecnt]=i;
    		for(int j=1;j<=primecnt;j++){
    			if(i*prime[j]>N) break;
    			is_prime[i*prime[j]]=1;
    			if(i%prime[j]) break;
    		}
    	}
    }
    
    signed main(){
    	init(N);
    	while(~(scanf("%d%d",&l,&r))){
    		memset(sum,0,sizeof sum);
    		if(l==1) l++;
    		for(int i=1;i<=primecnt;i++){
    			for(int j=l/prime[i];j<=r/prime[i];j++){
    				if(prime[i]*j<l) continue;
    				if(j==1) continue;
    				sum[prime[i]*j-l]=1;
    			}
    		}
    		int tot=0,last=0;
    		int max1,max2,min1,min2;
    		int maxn=0xcfcfcfcf,minn=0x3f3f3f3f;
    		for(int i=0;i<=r-l;i++){
    			//printf("i=%d,sum=%d
    ",i,sum[i]);
    			if(sum[i]) continue;
    			tot++;
    			if(tot>1){
    				if(maxn<i-last){
    					maxn=i-last;
    					max1=last,max2=i;
    				}
    				if(minn>i-last){
    					minn=i-last;
    					min1=last,min2=i;
    				}
    			}
    			last=i;
    		}
    		if(tot==1)
    			printf("There are no adjacent primes.
    ");
    		else
    			printf("%d,%d are closest, %d,%d are most distant.
    ",min1+l,min2+l,max1+l,max2+l);
    	}
    	return 0;
    }
    
  • 相关阅读:
    python3爬虫-快速入门-爬取图片和标题
    数据库Mysql的学习(八)-储存过程和事务和导入导出
    数据库Mysql的学习(七)-自定义函数和流程控制
    git reset --hard HEAD^
    list采坑记录一下
    Linux运行jar包
    JSONObject.toJSONString(map)
    String转list
    判断list中元素是否是相邻
    统计List中相同的元素
  • 原文地址:https://www.cnblogs.com/YoungNeal/p/9026640.html
Copyright © 2011-2022 走看看