UVA10140PrimeDistance题解--质数/技巧
题目链接
https://www.luogu.org/problemnew/show/UVA10140
分析
\(L,R\)都很大,显然不能直接筛出\(L,R\)区间中的质数,这里需要一个结论
结论
任何一个合数\(N\)必定含有一个小于等于\(\sqrt N\)的质因子
证明
反证法,若所有质因子都大于\(\sqrt N\),那么无论怎么组合显然都大于\(N\)
于是通过这个结论筛出\([2,\sqrt R]\),中的所有素数,把它们看作质因子筛出\([L,R]\)中的所有合数
注意如果\(L\)为\(1\)的话需要注意,不要把\(1\)标记为质数,对拍了好久才发现...真坑啊
代码
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <cctype>
#include <queue>
#include <cmath>
#define ll long long
#define ri register int
using std::min;
using std::max;
template <class T>inline void read(T &x){
x=0;int ne=0;char c;
while(!isdigit(c=getchar()))ne=c=='-';
x=c-48;
while(isdigit(c=getchar()))x=(x<<3)+(x<<1)+c-48;
x=ne?-x:x;return ;
}
const int maxn=1500005;
const int inf=0x7fffffff;
int l,r;
bool ok[maxn],vis[50000];
int prime[50000],tot=0;
inline void get_prime(){
int lim=(int)(std::sqrt(1.0*inf+0.5));
//printf("%d\n",lim);
for(ri i=2;i<=lim;i++){
if(!vis[i]){
vis[i]=1;
prime[++tot]=i;
}
for(ri j=1;j<=tot&&1ll*prime[j]*i<=lim;j++){
vis[i*prime[j]]=1;
if(i%prime[j]==0)break;
}
}
return ;
}
inline void solve(int n){
int lim=(int)(std::sqrt(1.0*n+0.5));
memset(ok,0,sizeof(ok));
int o=1;
while(prime[o]<=lim&&o<=tot){
for(ri k=l/prime[o];k<=r/prime[o];k++){
if(k==1||k==0)continue;
/*注意k=1及k=0都是不合法的情况*/
ok[k*prime[o]-l]=1;
/*左移L位以储存结果*/
}
o++;
}
return ;
}
int main(){
freopen("dat.in","r",stdin);
freopen("wa.out","w",stdout);
get_prime();
while(scanf("%d %d",&l,&r)!=EOF){
/*注意!!!*/
if(l==1)l=2;
//注意!!! 1不是质数
int lnum,lst=-inf,xans=-1,ians=inf;
int a,b,c,d;
solve(r);
for(ri i=0;i<=r-l;i++){
if(!ok[i]){
if(lst!=-inf){
//xans=max(xans,i-lst);
if(i-lst>xans){
c=lst,d=i;
xans=i-lst;
}
if(i-lst<ians){
a=lst,b=i;
ians=i-lst;
}
//ians=min(ians,i-lst);
}
lst=i;
}
}
if(xans==-1){
puts("There are no adjacent primes.");
}
else{
printf("%d,%d are closest, %d,%d are most distant.\n",a+l,b+l,c+l,d+l);
}
}
return 0;
}
UVA10140PrimeDistance题解--质数/技巧的更多相关文章
- HDU 3415 Max Sum of Max-K-sub-sequence 单调队列题解
本题又是一题单调队列题解. 技巧就是须要计算好前n项和Sn = a1 + a2 + ... an 这样方便处理. 记录一条单调队列,其意义是: q(head), q(head+1), ...q(tai ...
- ACdream 1195 Sudoku Checker (数独)
Sudoku Checker Time Limit:1000MS Memory Limit:64000KB 64bit IO Format:%lld & %llu Submit ...
- [LeetCode] 196.删除重复的电子邮箱
编写一个 SQL 查询,来删除 Person 表中所有重复的电子邮箱,重复的邮箱里只保留 Id 最小 的那个. +----+------------------+ | Id | Email | +-- ...
- arc098E Range Minimum Queries
题意:给你一个n个数的数组,每次能够选取连续的长度为K的子序列,取出其中任意一个最小元素. 一共操作Q次.问取出的元素中Max-Min最小是多少? 标程: #include<bits/stdc+ ...
- soj114 中位数
题意:给你一个长度为2n-1的数组A,设Bi是A的1~2i-1的中位数.问打乱A,有多少种不同的B序列? 标程: #include<bits/stdc++.h> using namespa ...
- [USACO08OPEN]牛的街区Cow Neighborhoods
题目描述: luogu 题解: 技巧题. 曼哈顿距离:$|x1-x2|+|y1-y2|$ 切比雪夫距离:$\max(|x1-x2|,|y1-y2|)$ 曼哈顿距离转切比雪夫距离:$(x,y)-> ...
- P1217 [USACO1.5]回文质数 Prime Palindromes(技巧+暴力枚举+线性筛)
技巧:就是偶数位的回文数字一定不是质数---------证明:奇数位之和sum1==偶数位之和sum2的数字可以被11整除.(11除外,这是一个坑点) 最高位,最低位必须是 1, 3, 7, 9 暴力 ...
- 【题解】HDU4689 Derangement(有技巧的计数DP)
[题解]HDU4689 Derangement(有技巧的计数DP) 传送门 呵呵没告诉我多测组数,然后\(n\le 20,7000\mathrm{ms}\)我写了个状压上去T了 题目大意: 要你求错排 ...
- 《LeetBook》leetcode题解(7): Reverse Integer[E]——处理溢出的技巧
我现在在做一个叫<leetbook>的开源书项目,把解题思路都同步更新到github上了,需要的同学可以去看看 书的地址:https://hk029.gitbooks.io/leetboo ...
随机推荐
- nodeJS 项目如何运行
nodeJS 项目如何运行 一.总结 一句话总结: nodejs项目根目录中用node xx.js 或是 node xx运行 打开 window的 cmd 命令窗口,使用 cd 命令跳转到 nodeJ ...
- 美国top200药品2
python机器学习-乳腺癌细胞挖掘(博主亲自录制视频)https://study.163.com/course/introduction.htm?courseId=1005269003&u ...
- ELK的安全解决方案 X-Pack(1)
安装 X-Pack 前必须安装 elasticsearch. Kibana.logstash,因为之前安装ELK选择的版本都是5.4.1,所以这次选择X-Pack的版本也要是5.4.1的 第一步:下载 ...
- 断句:Store all parameters but the first passed to this function as an array
// Store all parameters but the first passed to this function as an array //除了第一个参数,把调用publish函数时的所有 ...
- ubuntu Tensorflow object detection API 开发环境搭建
https://blog.csdn.net/dy_guox/article/details/79111949 luo@luo-All-Series:~$ luo@luo-All-Series:~$ s ...
- 阶段5 3.微服务项目【学成在线】_day05 消息中间件RabbitMQ_11.RabbitMQ研究-工作模式-路由工作模式测试
先常见生产者 复制02的代码 先改一下交换机的名称 还需要制定routingKey.因为是两个消息 所以指定了两个routingKey 这里修改为当前指定的交换机名称 交换机和队列在绑定的时候指定我们 ...
- JavaScript 运行机制:Event事件循环机制
JavaScript Event事件循环机制 JS是单线程的,浏览器只分配一个主线程给JS.一次只能执行一个任务,当前任务执行完后在可以执行下一个任务.任务多时,就会形成任务队列排队等待执行.但是非常 ...
- 【UE】常用的UltraEdit使用技巧
Tip 1: Alt+C 列模式可以说最初选择使用这个文本编辑软件,原因很简单,就是因为“她”具有列编辑模式.如果您还不知道什么是列编辑模式的话,我想您应该好好研究一下啦.这是一个超级“赞”的功能.在 ...
- windows进入指定目录
1.进入cmd 2.输入盘符比如:E: 3.切换目录 cd E:\progect\Firstdjango 实例:
- 使用super函数----增量重写普通方法和构造方法
使用super函数----增量重写普通方法和构造方法 在子类中如果重写了超类的方法,通常需要在子类方法中调用超类的同名方法,也就是说,重写超类的方法,实际上应该是一种增量的重写方式,子类方法会在超类的 ...