博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Primes on Interval(二分 + 素数打表)
阅读量:6327 次
发布时间:2019-06-22

本文共 2094 字,大约阅读时间需要 6 分钟。

Primes on Interval
Time Limit:1000MS     Memory Limit:262144KB     64bit IO Format:%I64d & %I64u
   
Appoint description:
 System Crawler  (2016-04-26)

Description

You've decided to carry out a survey in the theory of prime numbers. Let us remind you that a prime number is a positive integer that has exactly two distinct positive integer divisors.

Consider positive integers a, a + 1, ..., b(a ≤ b). You want to find the minimum integer l(1 ≤ l ≤ b - a + 1) such that for any integer x(a ≤ x ≤ b - l + 1) among l integers x, x + 1, ..., x + l - 1 there are at least k prime numbers.

Find and print the required minimum l. If no value l meets the described limitations, print -1.

Input

A single line contains three space-separated integers a, b, k (1 ≤ a, b, k ≤ 106a ≤ b).

Output

In a single line print a single integer — the required minimum l. If there's no solution, print -1.

Sample Input

Input
2 4 2
Output
3
Input
6 13 1
Output
4
Input
1 4 3
Output
-1 题意: 求最小的l使 x, x + 1, ..., x + l - 1 there are at least k prime numbers; 简单二分;
#include
#include
#include
#include
using namespace std;const int MAXN = 1e6 + 100;int dp[MAXN];int vis[MAXN];void db(){ memset(vis, 0, sizeof(vis)); vis[1] = 1; for(int i = 2; i <= sqrt(MAXN); i++){ if(!vis[i]){ for(int j = i * i; j < MAXN; j += i){ vis[j] = 1; } } } dp[0] = 0; for(int i = 1; i < MAXN; i++){ dp[i] = dp[i - 1]; if(!vis[i])dp[i]++; }}bool js(int l, int a, int b, int k){ for(int i = a; i <= b - l + 1; i++){ if(dp[i + l - 1] - dp[i - 1] < k)return false; } return true;}int erfen(int l, int r, int a, int b, int k){ int mid, ans = -1; while(l <= r){ mid = (l + r) >> 1; if(js(mid, a, b, k)){ ans = mid; r = mid - 1; } else l = mid + 1; } return ans;}int main(){ db(); int a, b, k; while(~scanf("%d%d%d", &a, &b, &k)){ printf("%d\n", erfen(0, b - a + 1, a, b, k)); } return 0;}

 

转载地址:http://wrgaa.baihongyu.com/

你可能感兴趣的文章
BASE64编码解码
查看>>
Flask总结
查看>>
获得表字段名称和数据类型
查看>>
关键帧动画实现圆弧动画
查看>>
openwrt 按下回车才能显示图标信息
查看>>
codeforces 600A Extract Numbers
查看>>
LinearLayout控件
查看>>
tomcat 配置项目
查看>>
事件类型
查看>>
7、RabbitMQ-主题模式
查看>>
MVC & MVP 模式
查看>>
HDU 5340 Three Palindromes(Manacher)
查看>>
转载利用线性渐变实现晴天、多云特效
查看>>
软件架构自学笔记——质量属性之淘宝网的常见属性场景
查看>>
[转载] 七龙珠第一部——第123话 如意棒的秘密
查看>>
ts 与 C#的 一个差异的地方
查看>>
django模板-自定义标签、过滤器
查看>>
Dreamweaver使用过程的小技巧
查看>>
2017年12月13日高级软件测试技术实践作业3
查看>>
session和cookie的介绍
查看>>