呵呵哒,1001的dfs返回值写错,wa了两发就没分了,1002显然是PAM可是我没学过啊!!!压位暴力可不可以。。。看看范围貌似不行,弃疗。。。1003根本不会做,1004想了想lcc发现不可做,那就是仙人掌分治,没写完囧。。。

最后Rating+69滚粗了。。。

官方题解:

1001 Untitled

对于一组可能的答案cc,如果先对一个觉小的c_ic​i​​取模,再对一个较大的c_jc​j​​取模,那么这个较大的c_jc​j​​肯定是没有用的。因此最终的答案序列中的cc肯定是不增的。那么就枚举选哪些数字,并从大到小取模看看结果是否是00就可以了。时间复杂度O(2^n)O(2​n​​).

1002 Three Palindromes

对原串前缀和后缀作一个01标记pre[i],suf[i]表示1-i和i-n能否能形成回文。记以i为中心的回文半径为r(i)。

这些都可以在O(N)时间内求出。也可以使用Hash+二分等方法O(NlogN)内求出。

我们考虑中间一个回文串的位置,不妨设它是奇数长度(偶数类似)。

那么问题变成了求一个i和d使得1<=d<=r(i)且pre[i-d]和suf[i+d]为真。

枚举i,实际上就是问pre[i-r(i)..i-1]和suf[i+1..i+r(i)]取反后 这两段有没有一个位置两者均为1,也就是and后不为0,暴力压位即可。

总时间复杂度为O(N^2/32)O(N​2​​/32)。

1003 Gcd and Lcm

详见推导。

Ans=\sum_{i=1}^n\sum_{j=1}^n\sum_{k=1}^n\sum_{l=1}^n [(i,j),(k,l)]Ans=∑​i=1​n​​∑​j=1​n​​∑​k=1​n​​∑​l=1​n​​[(i,j),(k,l)] 不妨先考虑下式

r(n,d)=\sum_{i=1}^n\sum_{j=1}^n [(i,j)=d]r(n,d)=∑​i=1​n​​∑​j=1​n​​[(i,j)=d]

令f(n)=r(n,1),则r(n,d)可以等价于f(n/d)。

f(n)=sum_{i=1}^{n}\sum_{j=1}^{n}f(n)=sum​i=1​n​​∑​j=1​n​​ e[(i,j)] (e为单位函数) = sum_{d=1}^{n} u(d) [n/d]^{2}=sum​d=1​n​​u(d)[n/d]​2​​

令d1=(i,j),d2=(k,l)那么不难得出

Ans=\sum_{d1=1}^n\sum_{d2=1}^n [d1,d2] f(n/d1)f(n/d2)Ans=∑​d1=1​n​​∑​d2=1​n​​[d1,d2]f(n/d1)f(n/d2)

令p=(d1,d2)则

\sum_{p=1}^n\sum_{d1=1}^{n/p}\sum_{d2=1}^{n/p} p*d1*d2*f(n/p/d1)*f(n/p/d2) e((d1,d2))∑​p=1​n​​∑​d1=1​n/p​​∑​d2=1​n/p​​p∗d1∗d2∗f(n/p/d1)∗f(n/p/d2)e((d1,d2))

\sum_{p=1}^n\sum_{q=1}^{n/p}\sum_{d1=1}^{n/p/q}\sum_{d2=1}^{n/p/q} u(q)*p*q*q*d1*d2*f(n/q/d1)*f(n/q/d2)∑​p=1​n​​∑​q=1​n/p​​∑​d1=1​n/p/q​​∑​d2=1​n/p/q​​u(q)∗p∗q∗q∗d1∗d2∗f(n/q/d1)∗f(n/q/d2)

令T=p*qT=p∗q

令g(n)=\sum_{d=1}^{n} u(d) f(n/d)^2g(n)=∑​d=1​n​​u(d)f(n/d)​2​​

s(n)=\sum_{d|n} u(d)*d^2*(n/d)s(n)=∑​d∣n​​u(d)∗d​2​​∗(n/d)

则化简得Ans=\sum_{T=1}^n s(T)*g(n/T)Ans=∑​T=1​n​​s(T)∗g(n/T)

s为积性函数,可以O(N)时间内预处理出1-N的所有函数值。 可惜的是g并非积性函数,但我们亦可以在O(sqrt(N))的时间求出g(N)。 在最后的答案中我们对g(n/T)的每种取值均算一遍即可,注意多组数据时记忆化。

1004 Dynamic Cactus

考虑离线,并对仙人掌进行分治。

类似于树的点分,每次的分治中心无非是两种情况:节点或者环。

这样每次新建节点时就去更新过分治中心的答案。

为了保证更新答案的两个点分属不同子树:

对于普通节点,只要维护最大和在另一子树的次大距离即可;对于环,由于环上的距离计算存在序的问题以及两种走法,我们可以在环上任选一个开始位置,需要分前后两部分更新和询问,可以用四个BIT维护前缀后缀和正负符号。

总时间复杂度为O(NlogNlogN)O(NlogNlogN)。

1001:

 #include<iostream>
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<queue>
#include<cstring>
#define PAU putchar(' ')
#define ENT putchar('\n')
using namespace std;
const int maxn=+,inf=1e9;
inline int read(){
int x=,sig=;char ch=getchar();
while(!isdigit(ch)){if(ch=='-')sig=-;ch=getchar();}
while(isdigit(ch))x=*x+ch-'',ch=getchar();
return x*=sig;
}
inline void write(int x){
if(x==){putchar('');return;}if(x<)putchar('-'),x=-x;
int len=,buf[];while(x)buf[len++]=x%,x/=;
for(int i=len-;i>=;i--)putchar(buf[i]+'');return;
}
int A[maxn],T,n,p[maxn],num;
int dfs(int now,int l,int tot){
if(l>n)return inf;
if(now%p[l]==)return tot;
return min(dfs(now%p[l],l+,tot+),dfs(now,l+,tot));
}
void init(){
T=read();
while(T--){
n=read();num=read();
for(int i=;i<=n;i++)A[i]=read();
if(num==){puts("");continue;}
sort(A+,A++n);
for(int i=;i<=n;i++)p[i]=A[n-i+];
//for(int i=1;i<=n;i++)write(p[i]),PAU;
int tmp=dfs(num,,);
if(tmp!=inf)write(tmp),ENT;
else puts("-1");
//write(dfs(num,1));ENT;
} return;
}
void work(){
return;
}
void print(){
return;
}
int main(){init();work();print();return ;}

BestCoder Round #49的更多相关文章

  1. Manacher BestCoder Round #49 ($) 1002 Three Palindromes

    题目传送门 /* Manacher:该算法能求最长回文串,思路时依据回文半径p数组找到第一个和第三个会文串,然后暴力枚举判断是否存在中间的回文串 另外,在原字符串没啥用时可以直接覆盖,省去一个数组空间 ...

  2. DFS BestCoder Round #49 ($) 1001 Untitled

    题目传送门 /* DFS:从大到小取模,因为对比自己大的数取模没意义,可以剪枝.但是我从小到大也过了,可能没啥大数据 */ /************************************* ...

  3. CodeForce Round#49 untitled (Hdu 5339)

    Untitled Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Su ...

  4. hdu 5195 DZY Loves Topological Sorting BestCoder Round #35 1002 [ 拓扑排序 + 优先队列 || 线段树 ]

    传送门 DZY Loves Topological Sorting Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 131072/131 ...

  5. BestCoder Round #89 02单调队列优化dp

    1.BestCoder Round #89 2.总结:4个题,只能做A.B,全都靠hack上分.. 01  HDU 5944   水 1.题意:一个字符串,求有多少组字符y,r,x的下标能组成等比数列 ...

  6. BestCoder Round #90 //div all 大混战 一题滚粗 阶梯博弈,树状数组,高斯消元

    BestCoder Round #90 本次至少暴露出三个知识点爆炸.... A. zz题 按题意copy  Init函数 然后统计就ok B. 博弈 题  不懂  推了半天的SG.....  结果这 ...

  7. bestcoder Round #7 前三题题解

    BestCoder Round #7 Start Time : 2014-08-31 19:00:00    End Time : 2014-08-31 21:00:00Contest Type : ...

  8. Bestcoder round #65 && hdu 5593 ZYB's Tree 树形dp

    Time Limit: 3000/1500 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)Total Submissio ...

  9. Bestcoder round #65 && hdu 5592 ZYB's Premutation 线段树

    Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)Total Submissio ...

随机推荐

  1. 最蛋疼的bug:读取图片缩略图(一定要在相冊查看下形成缓存)

    近期的一个连接服务端的应用.须要读取图片,一般供用户公布商品选择上传图片.初始的图片列表应该是缩略图.仅仅有确定了,才上传原图,OK不多说上代码 package edu.buaa.erhuo; imp ...

  2. [Angular 2] Passing data to components with 'properties'

    Besides @Input(), we can also use properties on the @Component, to pass the data. import {Component, ...

  3. is not in the sudoers file.This incident will be reported

    解决方法如下: 1>.进入超级用户模式.也就是输入"su -",系统会让你输入超级用户密码,输入密码后就进入了超级用户模式. 2>.添加文件的写权限.也就是输入命令&q ...

  4. 安全框架Shiro和Spring Security比较

    Shiro 首先Shiro较之 Spring Security,Shiro在保持强大功能的同时,还在简单性和灵活性方面拥有巨大优势. Shiro是一个强大而灵活的开源安全框架,能够非常清晰的处理认证. ...

  5. KVM与VMware的性能比较

    结合网页http://www.linuxidc.com/Linux/2011-01/31755.htm等整理 物理环境内存4G ,CPU4个,动态硬盘120G KVM: 硬盘测试瞬间读取速度Timin ...

  6. Bellman_ford POJ 3259 Wormholes

    Wormholes Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 41728   Accepted: 15325 Descr ...

  7. Python os常用模块

    Python的标准库中的os模块包含普遍的操作系统功能.如果你希望你的程序能够与平台无关的话,这个模块是尤为重要的.即它允许一个程序在编写后不需要任何改动,也不会发生任何问题,就可以在Linux和Wi ...

  8. MySQL 管理

    MySQL 管理 启动及关闭 MySQL 服务器 首先,我们需要通过以下命令来检查MySQL服务器是否启动: ps -ef | grep mysqld 如果MySql已经启动,以上命令将输出mysql ...

  9. Active控件有关问题

    ActiveX 控件是允许网站提供视频等内容的网站. 当你浏览 Web 时,它们允许你使用工具栏.股票代号.视频和其它内容. 但是,这些程序有时可能出现问题,或者向你提供不需要的内容. 在某些情况下, ...

  10. 跟我学android-使用Eclipse开发第一个Android应用(三)

    打开Eclipse,选择 File—New –Android Application Project Application Name  就是我们的 应用名称,也是我们在手机应用程序列表里看到的名称. ...