传送门

nmdwsm

自己看吧,不想写了qwq

垃圾代码如下 和题解完全不一样

#define LL long long
#define uLL unsigned long long
#define il inline
#define re register using namespace std;
const int M=1e7+10,N=1e5+10;
il int rd()
{
int x=0,w=1;char ch=0;
while(ch<'0'||ch>'9') {if(ch=='-') w=-1;ch=getchar();}
while(ch>='0'&&ch<='9') {x=(x<<3)+(x<<1)+(ch^48);ch=getchar();}
return x*w;
}
uLL hb[M],bb[M],bs=2333;
vector<char> cc[N];
int l[N],r[N],s[N];
bool v[N];
string fk; int main()
{
freopen("3574.in","r",stdin);
freopen("3574.out","w",stdout);
bb[0]=1;
for(int i=1;i<M-1;++i) bb[i]=bb[i-1]*bs;
int T=rd();
while(T--)
{
int n=rd();
for(int i=0;i<=n;++i) v[i]=0;
int m=0;
char ch;
/*while(233)
{
ch=getchar();
if(ch=='\n'||ch==-1)
{
++m;
if(m>=n) break;
l[m]=0,r[m]=-1,cc[m].clear();
}
else ++r[m],cc[m].push_back(ch);
}*/
for(int i=0;i<n;++i)
{
l[i]=0,cc[i].clear();
cin>>fk;
//int nmd=((int)fk.length())-1;
r[i]=((int)fk.length())-1;
for(int j=l[i];j<=r[i];++j) cc[i].push_back(fk[j]);
}
m=n;
while(233)
{
int i=0;
ch=0;
while(i<m)
{
int j=i;
if(l[j]>r[j]) break;
if(cc[j][l[j]]=='*') break;
if(!ch||ch==cc[j][l[j]]) ch=cc[j][l[j]];
else break;
++i;
}
if(i<m||!ch) break;
for(int j=0;j<m;++j) ++l[j];
}
while(233)
{
int i=0;
ch=0;
while(i<m)
{
int j=i;
if(l[j]>r[j]) break;
if(cc[j][r[j]]=='*') break;
if(!ch||ch==cc[j][r[j]]) ch=cc[j][r[j]];
else break;
++i;
}
if(i<m||!ch) break;
for(int j=0;j<m;++j) --r[j];
}
uLL ha=0;
int h=0,px=0,py=1;
while(h<n)
{
uLL hh=0;
bool o=0;
for(int i=l[h];i<=r[h];++i)
{
if(cc[h][i]!='*') hh=hh*bs+cc[h][i];
else o=1;
}
if(o) {++h;continue;}
v[h]=1;
if(!px||ha==hh) px=1,ha=hh;
else py=0;
++h;
}
if(!py) {puts("N");continue;}
if(px)
{
int i,ma=0;
for(i=0;i<n;++i)
if(v[i]) {swap(cc[i],cc[0]),swap(v[i],v[0]),swap(l[i],l[0]),swap(r[i],r[0]);break;}
for(i=0;i<n;++i) ma=max(ma,r[i]);
hb[0]=cc[0][0];
for(i=1;i<=r[0];++i) hb[i]=hb[i-1]*bs+cc[0][i];
for(i=r[0]+1;i<=ma;++i) hb[i]=0;
for(i=1;i<n;++i)
{
if(v[i]) continue;
ha=0;
int j=l[0],k=r[0],ll=0;
while(l[i]<=r[i]&&j<=k&&cc[i][l[i]]==cc[0][j]) ++l[i],++j;
while(l[i]<=r[i]&&j<=k&&cc[i][r[i]]==cc[0][k]) --r[i],--k;
if(l[i]<=r[i]&&(cc[i][l[i]]!='*'||cc[i][r[i]]!='*')) break;
while(l[i]<=r[i]&&j<=k)
{
if(cc[i][l[i]]!='*') ++ll,++j,ha=ha*bs+cc[i][l[i]];
else
{
if(ll)
{
while(j<=k&&ha!=hb[j]-hb[j-ll]*bb[ll]) ++j;
if(j>k) l[i]=-233;
}
ll=0,ha=0;
}
++l[i];
}
while(l[i]>=0&&l[i]<=r[i]&&cc[i][l[i]]=='*') ++l[i];
if(l[i]<=r[i]) break;
}
puts(i>=n?"Y":"N");
continue;
}
for(int i=0;i<n;++i) s[i]=i;
m=n;
while(233)
{
int i=0;
ch=0;
while(i<m)
{
int j=s[i];
if(l[j]>r[j]) break;
if(cc[j][l[j]]=='*') swap(s[i],s[m-1]),--m,--i;
else if(!ch||ch==cc[j][l[j]]) ch=cc[j][l[j]];
else break;
++i;
}
if(i<m||!ch) break;
for(int j=0;j<m;++j) ++l[s[j]];
}
for(int i=0;i<n;++i) s[i]=i;
m=n;
while(233)
{
int i=0;
ch=0;
while(i<m)
{
int j=s[i];
if(l[j]>r[j]) break;
if(cc[j][r[j]]=='*') swap(s[i],s[m-1]),--m,--i;
else if(!ch||ch==cc[j][r[j]]) ch=cc[j][r[j]];
else break;
++i;
}
if(i<m||!ch) break;
for(int j=0;j<m;++j) --r[s[j]];
}
int c1=0,c2=0;
for(int i=0;i<n;++i) c1+=l[i]>r[i]||v[i],c2+=l[i]<=r[i]&&cc[i][l[i]]=='*'&&cc[i][r[i]]=='*';
puts(c1==n||c2==n?"Y":"N");
}
return 0;
}

md我是真的\(**\),分类讨论没考虑完全,数组开小,局部变量开的过大,没清空数组,没考虑空行,然后写了一万年,,,

8说了

luogu P3234 [HNOI2014]抄卡组的更多相关文章

  1. bzoj3574[Hnoi2014]抄卡组

    http://www.lydsy.com/JudgeOnline/problem.php?id=3574 我们发现如果所有的字符串都有*,那么只需要比较他们的“前缀”和“后缀”相同即可.“前缀”指第一 ...

  2. 【LG3234】[HNOI2014]抄卡组

    题面 题解 分三种情况: 若所有串都没有通配符,直接哈希比较即可. 若所有串都有通配符, 把无通配符的前缀 和 无通配符的后缀哈希后比较即可. 中间部分由于通配符的存在,一定可以使所有串匹配. 若部分 ...

  3. BZOJ3574 HNOI2014抄卡组(哈希)

    容易发现通配符中间的部分可以任意匹配,会造成的无法匹配的仅仅是前后缀,前缀和后缀可以分别独立处理.如果字符串均有通配符,只需要按前/后缀长度排序然后暴力匹配就可以了. 问题在于存在无通配符的字符串.显 ...

  4. [HNOI2014]抄卡组

    [Luogu3234] [LOJ2208] 题解及代码 锻炼哈希码力的一道题 , 具体细节见代码 #include<cstdio> #include<cstring> #inc ...

  5. 洛谷P3234 抄卡组 [HNOI2014] 字符串hash

    正解:字符串hash 解题报告: 传送门! 字符串hash是字符串匹配中很常见的一个方法,原理也很好懂,这里就不做太多阐述辣有时间放到hash笔记里面去QAQ 题意不说了挺好理解的,自带一句话概括好评 ...

  6. 【HNOI2014】抄卡组

    题面 题解 如果所有的字符串都有通配符,那么只要比较不含通配符的前缀和后缀就可以了. 否则一定有一个串没有通配符.找出这个字符串,然后将所有串与这个串匹配,通配符将\(B\)分成一段一段在\(A\)上 ...

  7. 【LOJ6254】最优卡组 堆(模拟搜索)

    [LOJ6254]最优卡组 题面 题解:常用的用堆模拟搜索套路(当然也可以二分).先将每个卡包里的卡从大到小排序,然后将所有卡包按(最大值-次大值)从小到大排序,并提前处理掉只有一张卡的卡包. 我们将 ...

  8. HearthBuddy卡组

    偶数萨 手打两天已上传说,各位加油  欧洲牧羊人 ### 火元素换艾雅# 职业:萨满祭司# 模式:狂野模式## 2x (2) 图腾魔像        # 2x (2) 大漩涡传送门   # 2x (2 ...

  9. 服务器&阵列卡&组raid 5

    清除raid信息后,机器将会读不到系统, 后面若进一步操作处理, raid信息有可能会被初始化掉,那么硬盘数据就有可能会被清空, 导致数据丢失, 否则如果只是清除raid信息,重做raid是可以还原系 ...

随机推荐

  1. bzoj4869: [Shoi2017]相逢是问候(欧拉函数+线段树)

    这题是六省联考的...据说数据还出了点锅,心疼六省选手QAQ 首先要知道扩展欧拉定理... 可以发现每次区间操作都会使模数进行一次phi操作,而一个数最多取logp次phi就会变成1,这时后面的指数就 ...

  2. Python 3 入门,看这篇就够了

    文章目录 简介 基础语法 运算符 变量 数据类型 流程控制 迭代器 生成器 函数 自定义函数 参数传递 可更改与不可更改对象 参数 匿名函数 变量作用域 模块 面向对象 错误和异常 文件操作 序列化 ...

  3. JavaScript深入之从原型到原型链

    构造函数创建对象 我们先使用构造函数创建一个对象: function Person(){} var person = new Person(); person.name = 'Kevin'; cons ...

  4. Spring MVC 架构的java web工程如何添加登录过滤器

    发布到外网的web工程必须添加登录过滤器来阻挡一些非法的请求,即只有登录的用户才能对web工程进行请求,否则无论请求什么资源都需要调整到登录页面进行登录操作.这时就需要用到过滤器,其实非常简单,只需要 ...

  5. 使用bedtools提取vcf多个位置的变异(extract multi-region of genotypes by bedtools)

    1.下载安装bedtools: 2.生成bed文件:标准的bed文件格式如下: chr7 127471196 127472363 Pos1 0 + 127471196 127472363 255,0, ...

  6. AndroidStudio快速入门四:打造你的开发工具,settings必备

    http://blog.csdn.net/jf_1994/article/details/50085825 前言:这里是使用AS的基本设置,适合新入手的朋友阅读,将这里介绍的设置完基本使用无忧啦. 1 ...

  7. js或jQuery获取当前屏幕的各种高度

    Javascript: 网页可见区域宽: document.body.clientWidth网页可见区域高: document.body.clientHeight网页可见区域宽: document.b ...

  8. sqlserver Timeout 时间已到。在操作完成之前超时时间已过或服务器未响应

      随着数据库数据的不断增大,查询时间也随之增长.今天在之前一个项目中执行数据库查询超过30秒就报“Timeout 时间已到.在操作完成之前超时时间已过或服务器未响应.”了,网上找了些文章,是在.co ...

  9. Kubernetes的负载均衡问题(Nginx Ingress)

    nginx 反向代理 https://www.cnblogs.com/ericnie/p/6965091.html Kubernetes 集群中使用 Traefik https://blog.csdn ...

  10. qml: 软件启用前插入广告;

    一般来说,免费软件或者部分商业软件在发布前都会放一些广告在软件上. 下面是我自己的方案(哪位有更好的方案,请告知,先谢): ...... ApplicationWindow{ visible: !ad ...