质数距离

题目TP门

题目描述

给定两个整数L和R,你需要在闭区间[L,R]内找到距离最接近的两个相邻质数C1和C2(即C2-C1是最小的),如果存在相同距离的其他相邻质数对,则输出第一对。

同时,你还需要找到距离最远的两个相邻质数D1和D2(即D1-D2是最大的),如果存在相同距离的其他相邻质数对,则输出第一对。

输入格式

每行输入两个整数L和R,其中L和R的差值不会超过1000000。‘

输出格式

对于每个L和R ,输出一个结果,结果占一行。

结果包括距离最近的相邻质数对和距离最远的相邻质数对。(具体格式参照样例)

如果L和R之间不存在质数对,则输出“There are no adjacent primes.”。

样例

样例输入

2 17
14 17

样例输出

2,3 are closest, 7,11 are most distant.
There are no adjacent primes.
数据范围

1≤L<R≤2147483647

解析

L,R范围很大,即使是线性筛法也无法在有限时间内筛选出质数。

我们知道,在任何一个合数n中,必有一个小于sqrt(n)的因子。

所以先用任意筛法(时间复杂度<=O(n))筛出所有在sqrt( R )中的质数。

把这些数记为p。


不难想到,在[L,R]中的数,只要不被p整除,就是质数。找出[L,R]中的质数之后,后面的操作就很简单了。

于是我就想到了枚举L~R中所有的数,能否被P整除

代码如下
#include <cstdio>
#include <cmath>
#include <vector>
#include <cstring>
using namespace std;
#define ll long long
const ll MAXN = 1e7 + 5;
vector<ll> zs;
bool f[MAXN];
ll ans1, ans2, ans3, ans4, maxn, minn;
ll l, r, size;
void Sqrt_R() {
ll i, j;
f[1] = 1;
size = 0;
zs.clear();
for (i = 2; i <= sqrt(r); i++) {
if (f[i])
continue;
zs.push_back(i);
for (j = 1; j <= sqrt(r) / i; j++) f[i * j] = 1;
}
}
void Prime_Number() {
ll i, j;
ll last, l1, cnt = 0;
minn = 0x3f3f3f3f;
maxn = -minn;
for (i = l; i <= r; i++) {
bool flag = 0;
for (vector<ll>::iterator it = zs.begin(); it != zs.end(); it++) {
if (i % (*it) == 0) {
flag = 1;
break;
}
}
if (i >= 2 && i <= sqrt(r))
if (flag && (!f[i]))
continue;
if (flag && (!(i >= 2 && i <= sqrt(r))))
continue;
cnt++;
if (cnt >= 2) {
ll min1 = i - last;
if (min1 < minn) {
ans1 = l1;
ans2 = i;
minn = min1;
}
ll max1 = i - last;
if (max1 > maxn) {
ans3 = l1;
ans4 = i;
maxn = max1;
}
}
last = i;
l1 = i;
}
if (cnt >= 2)
printf("%lld,%lld are closest, %lld,%lld are most distant.\n", ans1, ans2, ans3, ans4);
else
printf("There are no adjacent primes.\n");
}
int main() {
while (scanf("%lld %lld", &l, &r) != EOF) {
memset(f, 0, sizeof(f));
Sqrt_R();
Prime_Number();
}
return 0;
}

这种的时间复杂度是O((L-R)*sqrt( R)),于是,我超时了。



于是在上述方法的改进下,在找p的时候,把[L,R]中能整除p的数标记了,时间复杂度就可以减少到O(L-R),就不会超时。

正解
#include <cstdio>
#include <cmath>
#include <vector>
#include <cstring>
using namespace std;
#define ll long long
const ll MAXN = 1e7 + 5;
bool f[MAXN], p[MAXN];
ll ans1, ans2, ans3, ans4, maxn, minn;
ll l, r;
void Sqrt_R() {
ll i, j;
f[1] = 1;
for (i = 2; i <= sqrt(r); i++) {
if (f[i])
continue;
ll u = (l - 1) / i + 1;
while ((u * i) < l) u++;
if (u < 2)
u = 2;
while ((u * i) <= r) {
p[(u * i) - l] = 1;
u++;
}
}
}
void Prime_Number() {
ll i, j;
ll last, l1, cnt = 0;
minn = 0x7fffffff;
maxn = -minn;
for (i = l; i <= r; i++) {
if (!p[i - l] && i != 1) {
if (i - last < minn && cnt != 0) {
minn = i - last;
ans1 = last;
ans2 = i;
}
if (i - last > maxn && cnt != 0) {
maxn = i - last;
ans3 = last;
ans4 = i;
}
last = i;
cnt++;
}
}
if (cnt >= 2)
printf("%lld,%lld are closest, %lld,%lld are most distant.\n", ans1, ans2, ans3, ans4);
else
printf("There are no adjacent primes.\n");
}
int main() {
while (scanf("%lld %lld", &l, &r) != EOF) {
memset(f, 0, sizeof(f));
memset(p, 0, sizeof(p));
Sqrt_R();
Prime_Number();
}
return 0;
}

这道题用了埃氏筛法的思想。

单独来看,筛选1-n中的质数,时间复杂度只有O(n*log(n)),是竞赛中最常用的质数筛法。

POJ2689 [质数距离] 题解的更多相关文章

  1. poj2689 Prime Distance题解报告

    题目戳这里 [题目大意] 给定一个区间[L,R],求区间内的质数相邻两个距离最大和最小的. [思路分析] 其实很简单呀,很明显可以看出来是数论题,有关于质数的知识. 要注意一下的就是L和R的数据范围都 ...

  2. AcWing 196. 质数距离(筛法+离散化)打卡

    给定两个整数L和U,你需要在闭区间[L,U]内找到距离最接近的两个相邻质数C1和C2(即C2-C1是最小的),如果存在相同距离的其他相邻质数对,则输出第一对. 同时,你还需要找到距离最远的两个相邻质数 ...

  3. 力扣(LeetCode)计数质数 个人题解

    统计所有小于非负整数 n 的质数的数量. 示例: 输入: 10 输出: 4 解释: 小于 10 的质数一共有 4 个, 它们是 2, 3, 5, 7 . 一般方法,也就是一般人都会用的,将数从2到它本 ...

  4. LOJ P10130 点的距离 题解

    这道题相当于倍增求LCA的板子,我们只要构建一棵树,然后距离就是x的深度+y的深度 - LCA(x,y)的深度: #include<iostream> #include<cstdio ...

  5. 洛谷 P2136 拉近距离 题解

    P2136 拉近距离 题目背景 我是源点,你是终点.我们之间有负权环. --小明 题目描述 在小明和小红的生活中,有N个关键的节点.有M个事件,记为一个三元组(Si,Ti,Wi),表示从节点Si有一个 ...

  6. 【JZOJ4725】质数序列 题解(数学)

    题目大意:质数序列是指这个序列中任意两个数的和均为质数.先给出一个序列${a_{n}}$,从中取出元素构成最长质数序列,问其长度并输出序列.若长度相同则求和最大的序列.保证答案唯一. -------- ...

  7. 洛谷 P1279 字串距离 题解

    每日一题 day24 打卡 Analysis 字符串+dp 仔细观察发现,对于f[i][j],它的值为以下三个值中的最小者: f[i-1][j]+k //a[i]对应空格 f[i][j-1]+k // ...

  8. AcWing P173 矩阵距离 题解

    Analysis 就是一个裸的广搜,每次从是1的点开始找就好啦~~~ #include<iostream> #include<cstdio> #include<cstri ...

  9. ACwing 196. 质数距离

    #include <bits/stdc++.h> using namespace std; , M = ; int v[M]; long long prime[N],prim[N]; ; ...

随机推荐

  1. MySQL:SELECT COUNT 小结

    MySQL:SELECT COUNT 小结 背景 今天团队在做线下代码评审的时候,发现同学们在代码中出现了select count(1) . select count(*),和具体的select co ...

  2. 使用composer 显示错误美化

    新建comoser.json { "name": "brady_frmwork", "description":"php fram ...

  3. nginx 是如何处理过期事件的?

    目录 什么是过期事件 nginx 是如何处理过期事件的? 参考资料 什么是过期事件 对于不需要加入到 post 队列 延后处理的事件,nginx 的事件都是通过 ngx_epoll_process_e ...

  4. MySQL数据库基础-3-SQL 基本概念

    SQL 基本概念 约束:constraint,表中的数据要遵守的限制 主键:一个或多个字段的组合,填入的数据必须能在本表中唯一标识本行:必须提供数据,即NOT NULL,一个表只能有一个 惟一键:一个 ...

  5. 一键开启win10全局utf8,编码问题说拜拜

    在windows下开发,开发环境的配置是一个很头大的问题,而编码问题是另一个令人头大的问题,常常出现的中文乱码令人痛不欲生,其原因就在于windows默认的编码并不是现在很普遍的utf8格式,本文就来 ...

  6. Jetson AGX Xavier ROS下调用USB单目摄像头

    Jetson AGX Xavier安装的ROS是Melodic版本的,所以部署的时候用到的包都是Melodic的. 1. 查看USB摄像头 摄像头连接Xavier设备,调用命令查看. ls /dev/ ...

  7. 基于gin的golang web开发:模型绑定

    在前两篇文章介绍路由的时候,我们了解到gin可用通过类似DefaultQuery或DefaultPostForm等方法获取到前端提交过来的参数.参数不多的情况下也很好用,但是想想看,如果接口有很多个参 ...

  8. 《Head First 设计模式》:与设计模式相处

    正文 一.设计原则 1.封装变化 找出应用中可能需要变化之处,把它们独立出来,不要和那些不需要变化的代码混在一起. 2.针对接口编程,不针对实现编程 "针对接口编程"真正的意思是& ...

  9. Luogu P4957 [COCI2017-2018#6] Alkemija

    题意 有 \(n\) 种已知物质,现在手上有 \(m\) 种,每种无限多个.已知 \(k\) 种反应,每种可以将一些反应物变成一些生成物.求经过这些反应过后最多可以有多少种不同的物质. \(\text ...

  10. 使用MQTT协议的4G DTU模块具有什么优势

    什么是MQTT协议 要了解使用MQTT协议的4G DTU模块具有哪些优势,首先我们需要了解什么是MQTT协议,MQTT协议最早是IBM开发的一个即时通讯协议,它的主要是为大量计算能力有限且工作在低带宽 ...