BZOJ3752 : Hack
折半爆搜,首先爆搜出所有长度不超过$4$的串。
对于每个询问,首先暴力枚举所有长度不超过$4$的串,以及前$4$位相同时后面的串。
然后枚举前$4$位,以及后面的串长,那么后面的hash值唯一,可以双指针求出。
时间复杂度$O(26^4(\log(26^4)+k))$。
#include<cstdio>
#include<cstring>
#include<algorithm>
typedef long long ll;
typedef unsigned int U;
const int N=460000;
const ll inf=1LL<<60;
int seed,L,Q,ansl,sl;U H,mul[4];ll ans,ss,po[8];
struct P{U h;int s;P(){}P(U _h,int _s){h=_h,s=_s;}};
inline bool cmpa(const P&x,const P&y){return x.h<y.h;}
inline bool cmpb(const P&x,const P&y){return x.h==y.h?x.s<y.s:x.h<y.h;}
struct DS{
int n;P a[N];
void add(P t){a[++n]=t;}
void inita(){std::sort(a+1,a+n+1,cmpa);}
void initb(){
std::sort(a+1,a+n+1,cmpb);
int m=0;
for(int i=1;i<=n;i++)if(i==1||a[i].h!=a[i-1].h)a[++m]=a[i];
n=m;
}
}A[5],B[5],C[5];
void dfs(int l,U h,int s){
if(l)B[l].add(P(h,s)),C[l].add(P(h,s));
if(l==4){
for(int i=1;i<=4;i++)A[i].add(P(h*=seed,s));
return;
}
for(int i=0;i<26;i++)dfs(l+1,h*seed+i+'A',s+po[3-l]*i);
}
inline void up(ll x,int y){
if(x==ss&&y==sl)return;
if(x>ans)return;
if(x<ans||x==ans&&y<ansl)ans=x,ansl=y;
}
void solve(){
char s[100];
scanf("%s",s);
int n=strlen(s),i,j,k;
sl=n;
for(i=H=ss=0;i<n;i++)H=H*seed+s[i],ss+=po[7-i]*(s[i]-'A');
ans=inf;
for(i=1;i<=4&&i<=L;i++)for(j=1;j<=C[i].n;j++)if(C[i].a[j].h==H)up(1LL*po[4]*C[i].a[j].s,i);
if(sl>4&&sl<=L){
U tmp=0;ll t=0;
for(i=0;i<4;i++)tmp=tmp*seed+s[i],t+=po[7-i]*(s[i]-'A');
tmp*=mul[sl-4];
for(j=1;j<=C[sl-4].n;j++)if(tmp+C[sl-4].a[j].h==H)up(t+C[sl-4].a[j].s,sl);
}
for(i=1;i<=4&&i+4<=L;i++){
U o=~0U;
for(j=1,k=B[i].n;j<=A[i].n;j++){
U t=H-A[i].a[j].h;
if(t>o)k=B[i].n;
o=t;
while(k&&B[i].a[k].h>t)k--;
if(k&&B[i].a[k].h==t)up(1LL*po[4]*A[i].a[j].s+B[i].a[k].s,i+4);
}
}
if(ans==inf)puts("-1");
else{
for(i=0;i<ansl;i++)putchar(ans/po[7-i]%26+'A');
puts("");
}
}
int main(){
scanf("%d%d%d",&seed,&L,&Q);
for(int i=mul[0]=1;i<4;i++)mul[i]=mul[i-1]*seed;
for(int i=po[0]=1;i<8;i++)po[i]=po[i-1]*26;
dfs(0,0,0);
for(int i=1;i<=4;i++)A[i].inita(),B[i].initb();
while(Q--)solve();
return 0;
}
BZOJ3752 : Hack的更多相关文章
- css常用hack
原文地址:css常用hack 突然想起今天早上在CNZZ看到的统计数据,使用IE6.7的用户比例还真多,看到之后我的心都碎了.微软都放弃了为毛还有这么多人不死心? 所以说,IE下的兼容还是得做的. – ...
- CSS3_01之选择器、Hack
1.兄弟选择器:①相邻兄弟选择器:元素的后一个兄弟元素,选择器1+选择器2:②通用兄弟选择器:元素后的所有兄弟元素,选择器1~选择器2: 2.属性选择器:attr表示属性名称,elem表示元素名:①[ ...
- CSS Hack技术介绍及常用的Hack技巧集锦
一.什么是CSS Hack? 不同的浏览器对CSS的解析结果是不同的,因此会导致相同的CSS输出的页面效果不同,这就需要CSS Hack来解决浏览器局部的兼容性问题.而这个针对不同的浏览器写不同的CS ...
- Medial Queries的另一用法——实现IE hack
众所周知,有些时候为了实现IE下的某些效果与现代浏览器一致,我们不得不使用一些hack手段来实现目的.比如说使用"\0","\"和"\9"来 ...
- CSS Hack
CSS HACK,网上有很多,主要是IE版本不同造成的,尽量不要用CSS HACK,实在调不过去可以用一用,相信以后随着IE低版本的淘汰,CSS HACK也将不在使用. 类内部HACK IE6识别 - ...
- hack
1.Firefox @-moz-document url-prefix() { .selector { property: value; } }上面是仅仅被Firefox浏览器识别的写法,具体如: @ ...
- 浅谈CSS hack(浏览器兼容)
今天简单写一点关于浏览器兼容的处理方法,虽然百度上已经有很多,但是我还是要写! 先看一个图 这个图描述了2016年1月至8月网民们所使用的浏览器市场份额(来源:http://tongji.baidu. ...
- css3复杂选择器+内容生成+Css Hack
1.复杂选择器2.内容生成3.多列4.CSS Hack(浏览器兼容性)=======================================1.复杂选择器 1.兄弟选择器 1.特点: 1.通过 ...
- dedecms功能性函数封装(XSS过滤、编码、浏览器XSS hack、字符操作函数)
dedecms虽然有诸多漏洞,但不可否认确实是一个很不错的内容管理系统(cms),其他也不乏很多功能实用性的函数,以下就部分列举,持续更新,不作过多说明.使用时需部分修改,你懂的 1.XSS过滤. f ...
随机推荐
- curl实现发送Get和Post请求(PHP)
1.CURL介绍 CURL 是一个利用URL语法规定来传输文件和数据的工具,支持很多协议,如HTTP.FTP.TELNET等.最爽的是,PHP也支持 CURL 库.本文将介绍 CURL 的一些高级特性 ...
- Finalize()、Dispose()、SafeHandle、GC
Finalize https://msdn.microsoft.com/en-us/library/system.object.finalize%28v=vs.110%29.aspx https:// ...
- CentOS个人目录下中文路径转英文路径
CentOS个人目录下中文路径转英文路径 如果安装了中文版到CentOS之后,root目录及home目录下会出现中文到路径名,如"桌面"."文档"," ...
- EF唯一索引
this.Property(p => p.Name) .IsRequired() .HasMaxLength()) .HasColumnAnnotation("Index", ...
- Druid初步学习
Druid是一个JDBC组件,它包括三部分: DruidDriver 代理Driver,能够提供基于Filter-Chain模式的插件体系. DruidDataSource 高效可管理的数据库连接池 ...
- JSP与EL隐式对象
一,JSP隐式对象 隐式对象是可以直接使用的,无需声明.因为在JSP转译为servlet文件后,会自动声明其对象. 隐式对象① 说明 out 对应JspWriter对象,其内部关联一个PrintWri ...
- poj1399 hoj1037 Direct Visibility 题解 (宽搜)
http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...
- 大熊君JavaScript插件化开发------(实战篇之DXJ UI ------ ItemSelector重构完结版)
一,开篇分析 Hi,大家好!大熊君又和大家见面了,还记得上一篇文章吗.主要讲述了以“jQuery的方式如何开发插件”,以及过程化设计与面向对象思想设计相结合的方式是 如何设计一个插件的,两种方式各有利 ...
- CSS高效开发实战:CSS 3、LESS、SASS、Bootstrap、Foundation --读书笔记(4)构造尺寸更灵活的背景
相比传统的图片背景来说,使用CSS构造背景色不仅可以降低网络传输的开销,更由于其尺寸的可控性受到开发者的青睐. 如设计师设计了一张背景图片作为标题背景,如图5.18所示.对于用电脑浏览网页的用户来说, ...
- PHP的继承方法如何获取子类名?get_class() 和 get_called_class()
PHP里的__CLASS__这类东西是静态绑定的,如果不在子类里重载的话,那么继承父类方法所得到的依旧是父类的名称,而不是子类的名称,比如: <?php class A { function _ ...