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 ...
随机推荐
- Redis监控之redis-stat安装与详解
一.安装环境 安装编译环境.ruby运行环境.git代码 yum install gcc-c++ yum -y install ruby-devel yum install ruby yum inst ...
- 使 nodejs 代码 在后端运行(nohup)
1.代码 nohup node server.js & 说明: nohup 命令对 server.js 进程做了三件事 (1)阻止SIGHUP信号发到这个进程. (2)关闭标准输入.该进程不再 ...
- jmeter-Charles抓包显示的请求方式错误了,难道
抓包显示的请求方式为get,但是get一直报错见上图 将get修改为post就正确了
- windows把zookeeper注册成服务
1.官网下载zookeeper:http://mirrors.hust.edu.cn/apache/zookeeper/. 2.修改zookeeper下面的文件/zookeeper/conf/zoo_ ...
- mac下不允许安装除了app store之外的软件设置:
1.dock栏的系统偏好设置. 2.找到安全性与隐私 3.点击面板中的通用,在点击左小角的锁按钮, 4.选择任何来源,确定就可以了.[如果只有两个选项,而没有任何来源的话,打开终端,执行:sudo s ...
- JAVA 基础编程练习题50 【程序 50 文件 IO】
50 [程序 50 文件 IO] 题目:有五个学生,每个学生有 3 门课的成绩,从键盘输入以上数据(包括学生号,姓名,三门课成绩), 计算出平均成绩,将原有的数据和计算出的平均分数存放在磁盘文件&qu ...
- array_splice 在数组某位置插入数据
$arr=array('a','b','c','d','e','f','g');//目标数组 $i_arr=array(');//要插入的数组 $n=;//插入的位置 array_splice($ar ...
- nginx反向代理本地 两台web负载均衡 使用ip+端口代理
环境: 本地外网ip:123.58.251.166 .配置index.html网页 [root@host---- conf.d]# cat /web/sing/index.html <h1> ...
- 一条语句kill 多条mysql语句
If information_schema.processlist doesn’t exist on your version of MySQL, this works in a linux scri ...
- Sprint Retrospective - 回顾的重要性
在Scrum中,每个Sprint结束的时候会有两个会议(Sprint Review/Demo和Sprint Retrospective回顾).这两个会议是对过去的一个Sprint的一个总结,其中Rev ...