3136: [Baltic2013]brunhilda

Time Limit: 40 Sec  Memory Limit: 128 MB
Submit: 238  Solved: 73
[Submit][Status][Discuss]

Description

给定m个素数和Q个询问。每个询问有n个人,每次操作可以任意选择其中的一个素数p(素数可以重复使用),然后去掉剩余人数 mod p个人。对于每个询问,我们想知道,至少需要多少步操作才能去掉所有人。

Input

第一行:素数个数m和询问个数Q1 <= m <= 100 0001 <= Q <= 100 000)第二行:m个素数pi (2 <= pi <= 10 000 000)下面Q行:n (1 <= n <= 10 000 000

Output

Q行答案。如果无解,输出oo

Sample Input

2 2
2 3
5
6

Sample Output

3
oo

HINT

Source

 
【分析】
  40s。。你知道我有多大胆一开始还带个log做么。。。【最后T了一次,卡时过。。
  然后膜了一下栋爷爷

首先每次都去掉尽量多的人,可以证明这样贪心是最优的 
然后递推,f[i]表示i最少操作多少次到0,j表示当前离i最远的i-i%p[x]的点,f[i]=f[j]+1,如果j不满足条件了就要向后找j 
易知j一定是p[x]的倍数,预处理出每个数最小的质因数minp,对于i是不是p[x]的倍数只要看minp和i/minp是否是p[x]的倍数

时间复杂度O(n)

  那个贪心是因为f数组显然是递增的。然后我只能想到倍数之前了。

  后面那个好厉害,就是说那个j代表的质数能影响的长度不能超过这个质数本身,所以弄一个l表示那个数最远到那里。那就要看他是哪几些质数的倍数,然后选最大那个。

  就是max(l[x/mn[x]],l[mn[x]]) mn表示x的最小质因子【这里猴赛雷啊。。

 #include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
#define Maxn 10001000
#define Maxm 100010 inline int read()
{
int x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
} // int mymax(int x,int y) {return x>y?x:y;} int f[Maxn],mx;
int p[Maxm],q[Maxm]; int pri[Maxn/],pl,mn[Maxn],l[Maxn];
inline void init()
{
pl=;
memset(l,,sizeof(l));
mn[]=;
for(int i=;i<=mx;i++)
{
if(!l[i]) pri[++pl]=i,mn[i]=i;
for(int j=;j<=pl;j++)
{
if(pri[j]*i>mx) break;
mn[i*pri[j]]=pri[j];
l[i*pri[j]]=;
if(i%pri[j]==) break;
}
}
} int main()
{
int n,m;
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++) p[i]=read();
for(int i=;i<=m;i++) q[i]=read(),mx=mx>q[i]?mx:q[i];
// for(int i=1;i<=n;i++) scanf("%d",&p[i]);
// for(int i=1;i<=m;i++) scanf("%d",&q[i]);mx=mx>q[i]?mx:q[i];
init();
// memset(l,0,sizeof(l));
// memset(f,0,sizeof(f));
for(int i=;i<=mx;i++) l[i]=f[i]=;
l[]=;
for(int i=;i<=n;i++) l[p[i]]=p[i],l[]=l[]>p[i]?l[]:p[i]; int j=;
for(int i=;i<=mx;i++)
{
while(!l[j]||i-j>=l[j])
{
j++;
if(i==j) {mx=i-;break;}
}
f[i]=f[j]+;
// l[i]=mymax(l[i/mn[i]],l[mn[i]]);
l[i]=l[i/mn[i]]>l[mn[i]]?l[i/mn[i]]:l[mn[i]];
}
for(int i=;i<=m;i++)
{
if(q[i]>mx) printf("oo\n");
else printf("%d\n",f[q[i]]);
}
return ;
}

【那些20几秒咋做的啊?

2017-03-26 21:57:30

【BZOJ 3136】 3136: [Baltic2013]brunhilda (数论?)的更多相关文章

  1. 【BZOJ】【2219】数论之神

    中国剩余定理+原根+扩展欧几里得+BSGS 题解:http://blog.csdn.net/regina8023/article/details/44863519 新技能get√: LL Get_yu ...

  2. Bzoj 3505: [Cqoi2014]数三角形 数论

    3505: [Cqoi2014]数三角形 Time Limits: 1000 ms  Memory Limits: 524288 KB  Detailed Limits   Description

  3. bzoj 3834 [Poi2014]Solar Panels 数论分块

    3834: [Poi2014]Solar Panels Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 367  Solved: 285[Submit] ...

  4. 「BZOJ 2440」完全平方数「数论分块」

    题意 \(T\)组数据,每次询问第\(k\)个无平方因子的数(\(1\)不算平方因子),\(T\leq 50,k\leq 10^9\) 题解 \(k\)的范围很大,枚举肯定不行,也没什么奇妙性质,于是 ...

  5. BZOJ 3601: 一个人的数论

    题目链接:www.lydsy.com/JudgeOnline/problem.php?id=3601 题意: 思路: 因此可以用高斯消元得到ai. const int mod=1000000007; ...

  6. bzoj 2242 [SDOI2011]计算器(数论知识)

    Description 你被要求设计一个计算器完成以下三项任务: 1.给定y,z,p,计算Y^Z Mod P 的值: 2.给定y,z,p,计算满足xy≡ Z ( mod P )的最小非负整数: 3.给 ...

  7. bzoj 2226: [Spoj 5971] LCMSum 数论

    2226: [Spoj 5971] LCMSum Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 578  Solved: 259[Submit][St ...

  8. BZOJ 2301: [HAOI2011]Problem b( 数论 )

    和POI某道题是一样的...  http://www.cnblogs.com/JSZX11556/p/4686674.html 只需要二维差分一下就行了. 时间复杂度O(MAXN + N^1.5) - ...

  9. BZOJ 4305: 数列的GCD( 数论 )

    对于d, 记{ai}中是d的倍数的数的个数为c, 那么有: 直接计算即可,复杂度O(NlogN+MlogM) --------------------------------------------- ...

随机推荐

  1. IIS 网站日志分析

    最近由于ADSL代理总出问题,导致爬虫服务器总被目标网站封,由于请求内容总是空,前端APP获取不到想要的内容就一直刷新,导致爬虫服务器请求更加繁忙. 爬虫服务器每执行完一个流程,都会给统计服务器Pos ...

  2. 【BZOJ】3036: 绿豆蛙的归宿

    [题意]给定DAG带边权连通图,保证所有点都能到达终点n,每个点等概率沿边走,求起点1到终点n的期望长度.n<=10^5. [算法]期望DP [题解]f[i]表示到终点n的期望长度. f[n]= ...

  3. CodeForces - 877C

    Slava plays his favorite game "Peace Lightning". Now he is flying a bomber on a very speci ...

  4. styled-components真的好吗?

    最近在学习react,然后遇到react中css该怎么写这个问题,上知乎上看了好多大牛都说styled-components好用是大势所趋. 但我自己用了感觉体验却很差,我在这里说说我为啥觉得styl ...

  5. 2017ACM暑期多校联合训练 - Team 8 1008 HDU 6140 Hybrid Crystals (模拟)

    题目链接 Problem Description Kyber crystals, also called the living crystal or simply the kyber, and kno ...

  6. 2017ACM暑期多校联合训练 - Team 3 1005 RXD and dividing

    题目链接 Problem Description RXD has a tree T, with the size of n. Each edge has a cost. Define f(S) as ...

  7. vue使用jsx/axios拦截器设置

    最害怕的就是做过的事情,转几天又忘记了:写过的代码,也模模糊糊不知道哪里去了,所以告诉自己最好把每天遇到的问题记录下来,好,开始. 新公司要搭个vue后台框架,所以用了简简单单的 vue+iview+ ...

  8. Callback2.0

    Callback定义? a callback is a piece of executable code that is passed as an argument to other code, wh ...

  9. onvif客户端

    前言 做开发有8年时间了,ffmpeg和onvif与我是特别有缘的了(说着玩的,我更认为是因为他们确实强大^_^). ffmpeg在毕业设计时就有用到,5年后做windows.linux播放库时又有用 ...

  10. [node.js] async/await如何优雅处理异常?

    node.js的世界,从callback开始,不会止于async. 所有人都在骂为什么不能完全进化,其实我感觉这就是老外的细心,为了承上.这也就是为什么async其实就是promise一样,假如不是一 ...