题目描述

YJC把核弹发射密码忘掉了……其实是密码被加密了,但是YJC不会解密。密码由n个数字组成,第i个数字被加密成了如下形式:第k小的满足(2^L)|(P-1)且P为质数的P。YJC希望你能帮他算出密码是多少。

输入输出格式

输入格式:

第一行包含一个整数n,表示密码中的数字个数。

接下来n行每行两个整数L和k,表示一个数字的加密形式。

注意,输入格式变更,请注意L和k的先后顺序

输出格式:

输出n行,第i行一个整数,表示第i个数字。

输入输出样例

输入样例#1:

2
21 92
23 9
输出样例#1:

1998585857
998244353

说明

对于50%的数据,满足18≤n,L≤1000。

对于100%的数据,满足12≤n,L≤500000,保证答案<2^31。

分析:比较考验人品的一道题。

暴力找的话有30分.时间都浪费在了怎么判断素数上,而且询问很多,每个数可能会被判断多次,考虑怎么优化它们.

对于素数的判断,可以用一个比较考验人品的算法miller rabin测试,每一次都有大约1/4的概率会出错,因此要多判几次,但是多判几次又会超时,将次数控制在3次到5次就可以了.这里利用费马小定理+快速幂进行判断.

接下来考虑怎么不重复判断同一个数。我们将询问的L按照降序排序,符合条件的数肯定是k*2^i+1的形式,我们先从大到小枚举i,再枚举k,k枚举的是奇数,因为如果我们一个一个地枚举,如果k=2,那么就会跳到2^(i+1) + 1上去,而我们之前已经计算过了这个数,会造成重复.将所得的素数排个序.

最后考虑怎么快速得到第k小的p,因为我们已经将所得的素数排好序了,所以我们可以二分查找,由于之前我们将询问的L按照降序排列,那么得到的满足要求的数就构成了一个又一个的区间,那么利用树状数组来维护有多少个比它小的就可以了.

听说还有还可以用等差数列筛法,orz

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm> using namespace std;
const int maxn = << ,maxm = ; long long n,cnt,num[maxm],prime[maxm],t[maxm],ans[maxm],c[maxm];
struct node
{
long long l, k;
int id;
}e[maxm]; long long qpow(long long a, long long b, long long mod)
{
long long ans = ;
while (b)
{
if (b & )
ans = (ans * a) % mod;
b >>= ;
a = (a * a) % mod;
}
return ans;
} bool isok(long long x)
{
if (qpow(, x - , x) == && qpow(, x - , x) == && qpow(, x - , x) == )
return true;
return false;
} bool cmp1(node a, node b)
{
return a.l > b.l;
} int main()
{
scanf("%lld", &n);
for (int i = ; i <= n; i++)
{
scanf("%lld%lld", &e[i].l, &e[i].k);
e[i].id = i;
}
sort(e + , e + + n, cmp1);
for (int i = ; i >= ; num[i--] = cnt)
for (int j = ; 1LL * j * ( << i) < (1LL << ) - ; j += )
if (isok(j * ( << i) + ))
prime[++cnt] = j * ( << i) + ;
memcpy(t, prime, sizeof(prime));
sort(t + , t + + cnt);
for (int i = ; i <= cnt; i++)
prime[i] = lower_bound(t + , t + + cnt, prime[i]) - t; //实际上是把符合要求的质数和离散化了
int cur = ;
for (int i = ; i <= n; i++)
{ while (cur <= num[e[i].l])
{
for (int j = prime[cur]; j < maxn; j += j & -j)
c[j]++;
cur++;
} int l = , r = maxn, sum = ;;
while (l<r)
{
int mid = (l + r) >> ;
sum += c[mid];
if (sum >= e[i].k)
{
sum -= c[mid];
r = mid;
}
else l = mid + ;
}
ans[e[i].id] = t[l];
}
for (int i = ; i <= n; i++)
printf("%lld\n", ans[i]); return ;
}

noip模拟赛 密码的更多相关文章

  1. NOIP模拟赛20161022

    NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...

  2. contesthunter暑假NOIP模拟赛第一场题解

    contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...

  3. NOIP模拟赛 by hzwer

    2015年10月04日NOIP模拟赛 by hzwer    (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...

  4. 大家AK杯 灰天飞雁NOIP模拟赛题解/数据/标程

    数据 http://files.cnblogs.com/htfy/data.zip 简要题解 桌球碰撞 纯模拟,注意一开始就在袋口和v=0的情况.v和坐标可以是小数.为保险起见最好用extended/ ...

  5. 队爷的讲学计划 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的讲学计划 题解:刚开始理解题意理解了好半天,然后发 ...

  6. 队爷的Au Plan CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的Au%20Plan 题解:看了题之后觉得肯定是DP ...

  7. 队爷的新书 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的新书 题解:看到这题就想到了 poetize 的封 ...

  8. CH Round #58 - OrzCC杯noip模拟赛day2

    A:颜色问题 题目:http://ch.ezoj.tk/contest/CH%20Round%20%2358%20-%20OrzCC杯noip模拟赛day2/颜色问题 题解:算一下每个仆人到它的目的地 ...

  9. CH Round #52 - Thinking Bear #1 (NOIP模拟赛)

    A.拆地毯 题目:http://www.contesthunter.org/contest/CH%20Round%20%2352%20-%20Thinking%20Bear%20%231%20(NOI ...

随机推荐

  1. bzoj 1653: [Usaco2006 Feb]Backward Digit Sums【dfs】

    每个ai在最后sum中的值是本身值乘上组合数,按这个dfs一下即可 #include<iostream> #include<cstdio> using namespace st ...

  2. 小记 vue 打包(build)需要注意的一些事

    记录 vue 项目打包的一些事情 首先声明项目都是由 vue-cli 生成; vue 项目从 dev 切换到 prod 时有很多地方需要注意; 首先是大家最需要注意的 ajax 切换环节 以前一开始用 ...

  3. 三分 POJ 2420 A Star not a Tree?

    题目传送门 /* 题意:求费马点 三分:对x轴和y轴求极值,使到每个点的距离和最小 */ #include <cstdio> #include <algorithm> #inc ...

  4. 构造 Codeforces Round #107 (Div. 2) B. Phone Numbers

    题目传送门 /* 构造:结构体排个序,写的有些啰嗦,主要想用用流,少些了判断条件WA好几次:( */ #include <cstdio> #include <algorithm> ...

  5. 14 C#编程中的逻辑运算

    在C#编程中,我们经常需要处理这些情况. 1. 某种条件为真时,程序这样处理:当某种条件为假时,程序那样处理. 2. 当某种条件为真时,程序一直这样处理: 这里的条件,在C#中就是逻辑运算.接下来我就 ...

  6. 高性能队列disruptor为什么这么快?

    背景 Disruptor是LMAX开发的一个高性能队列,研发的初衷是解决内存队列的延迟问题(在性能测试中发现竟然与I/O操作处于同样的数量级).基于Disruptor开发的系统单线程能支撑每秒600万 ...

  7. 安装ipython notebook及基本命令(快捷键)

    转载自:http://121.42.47.99/yuenshome/wordpress/?p=2622 目前基本上是Pycharm和ipython notebook结合起来做东西,ipython no ...

  8. Microsoft SQL Server学习(三)

    1.表:表示一个实体(客观存在的事物或抽象时间),可实现对实体的数据描述和数据操作. 2.表结构:二位平面(行.列) 3.数据类型: 类型名称 类型 整形 bit(只存储0.1) samllint i ...

  9. Detectron-MaskRCnn:Mask判别和获取前向Mask的标签

    对于FCN-SceneParse网络,最后卷积生成N个类别的maps,每个Map都得到图像所有点的单类概率.MaskRCNN的结构与FCN不相同. 参考三个文章: Detectron总结1:Blob的 ...

  10. Codeforces_779_D.String Game_(二分)

    D. String Game time limit per test 2 seconds memory limit per test 512 megabytes input standard inpu ...