第一眼:什么鬼东西ヾ(。`Д´。)


第二眼:显然,这道题要分段处理 类似[TJOI2018]碱基序列\ (建议做一做也是Hash+DP)\ 那你怎么第一眼没看出来


Hash处理+DP==AC


直接上代码 (码风奇特请谅解,注释还算详细)

#include<cstdio>
#include<cstring>
#define _for(i,a,b) for(register int i=(a);i<=(b);i=-~i)
#define __for(i,a,b) for(register int i=(a);i>=(b);i=~-i)
#define Re register int
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
const int inf=2147483647,N=100000+20,M=11;
inline int re(){int x=0,f=0;
char ch=getchar();
while(ch>'9'||ch<'0')
f|=ch=='-',ch=getchar();
while(ch>='0'&&ch<='9')
x=(x<<1)+(x<<3)+(ch^48),ch=getchar();
return f?-x:x;
} char s1[N],s2[N];
ull hash1[110],hash2[N],p[N];
int len[110],n,cnt,hl,len2,num;
bool f[110][N];//懒得压维(按顺序处理到第几组、对应字符串中的哪一位) int main()
{
scanf("%s",s1+1);//从1开始存,个人习惯
n=re();
len[0]=strlen(s1+1);
_for(i,1,len[0])//分段
if(s1[i]=='*')//处理*和?
hash1[++cnt]='*';
else if(s1[i]=='?')
hash1[++cnt]='?';
else
if(s1[i-1]<'a'||s1[i-1]>'z')//前面不是字母,记录长度
hash1[++cnt]=s1[i]-'a'+1,len[cnt]=1;
else//前面是字母
hash1[cnt]=hash1[cnt]*131+s1[i]-'a'+1,len[cnt]++;
hl=len[0];
p[0]=1;//Hash 131进制
_for(i,1,len[0])
p[i]=p[i-1]*131;
while(n--)
{
scanf("%s",s2+1);
len2=strlen(s2+1);
_for(i,1,len2)//正常Hash
hash2[i]=hash2[i-1]*131+s2[i]-'a'+1;
memset(f,0,sizeof(f));
if(len2>hl)//小小的卡常
{
_for(i,hl+1,len2)
p[i]=p[i-1]*131;
hl=len2;
}
f[0][0]=1;//初始化!!!只初始化(0,0)
_for(i,1,cnt)
{
if(!len[i])//不是字母
{
if(hash1[i]=='?')
{//?是下一个字母任意
_for(j,0,len2)//由上一行向下转移
if(f[i-1][j])
f[i][j+1]=1;
}
else
{//*是之后的字母全任意
_for(j,0,len2)
if(f[i-1][j])
{
_for(k,j,len2)
f[i][k]=1;
break;
}
if(f[i-1][0]) f[i][0]=1;
}
continue;
}
_for(j,len[i],len2)//正常字符串匹配
if(hash1[i]==hash2[j]-hash2[j-len[i]]*p[len[i]]&&f[i-1][j-len[i]])
//一定是要能转移过来的
f[i][j]=1;
}
if(f[cnt][len2])//要求是完全匹配,所以只看放完最后一组最后一位是否能放
printf("YES\n");
else
printf("NO\n");
}
return 0;
}
/*
观察题目,通配符不超过10个
分段
Hash
跑DP
类似[TJOI2018]碱基序列
*/

[CQOI2014]通配符匹配 题解的更多相关文章

  1. P3167 [CQOI2014]通配符匹配 题解

    题目 题目大意 给出一个字符串,其中包含两种通配符 ‘?’和 ‘*’ ,‘?’可以代替一个字符,‘*’可以代替一个字符串(长度可以为0) 然后给出几个字符转,判断能否用给出的字符串表示出来 样例解释 ...

  2. 「题解报告」 P3167 [CQOI2014]通配符匹配

    「题解报告」 P3167 [CQOI2014]通配符匹配 思路 *和?显然无法直接匹配,但是可以发现「通配符个数不超过 \(10\) 」,那么我们可以考虑分段匹配. 我们首先把原字符串分成多个以一个通 ...

  3. BZOJ3507 [Cqoi2014]通配符匹配

    题意 几乎所有操作系统的命令行界面(CLI)中都支持文件名的通配符匹配以方便用户.最常见的通配符有两个,一个是星号("*"),可以匹配0个及以上的任意字符:另一个是问号(" ...

  4. BZOJ3507 [Cqoi2014]通配符匹配 【哈希 + 贪心】

    题目 几乎所有操作系统的命令行界面(CLI)中都支持文件名的通配符匹配以方便用户.最常见的通配符有两个,一个 是星号(""'),可以匹配0个及以上的任意字符:另一个是问号(&quo ...

  5. [CQOI2014]通配符匹配

    Description 几乎所有操作系统的命令行界面(CLI)中都支持文件名的通配符匹配以方便用户.最常见的通配符有两个,一个是星号(""'),可以匹配0个及以上的任意字符:另一个 ...

  6. bzoj 3507: [Cqoi2014]通配符匹配

    Description 几乎所有操作系统的命令行界面(CLI)中都支持文件名的通配符匹配以方便用户.最常见的通配符有两个,一个是星号(“”’),可以匹配0个及以上的任意字符:另一个是问号(“?”),可 ...

  7. 【bzoj3570】 Cqoi2014—通配符匹配

    http://www.lydsy.com/JudgeOnline/problem.php?id=3507 (题目链接) 题意 给出一个主串,里面有些通配符,'*'可以代替任意字符串或者消失,'?'可以 ...

  8. [BZOJ3507][CQOI2014]通配符匹配(DP+Hash)

    显然f[i][j]表示S匹配到第i个通配符,T匹配到第j个字符,是否可行. 一次一起转移两个通配符之间的所有字符,Hash判断. 稍微有点细节.常数极大卡时过排名倒数,可能是没自然溢出的原因. #in ...

  9. [bzoj3507 Cqoi2014]通配符匹配 (hash+DP)

    传送门 Solution 显然用哈希233 设\(f[i][j]\)表示第i个通配符和当前第j个字符是否匹配 考虑两种通配符的特性,直接转移即可 Code #include <cstdio> ...

  10. P3167 [CQOI2014]通配符匹配

    吐槽 本来是去写AC自动机的,然后发现数据范围每个串100000,有100个串(???),连塞进trie树里都塞不进去,玩个鬼的AC自动机啊,tag不要乱打啊 最后拿字符串hash+爆搜一发搜过去了. ...

随机推荐

  1. pip python的包成功,但是import的时候报错

    今天,一位同学线上反馈import python包失败了,同时附带两张图: 图1.报错代码 图2.报错提示 结合上面两个图片,我们发现这个同学import全部失败,初步怀疑该同学的本地环境上没有num ...

  2. JAVA格式化数字

    DecimalFormat df = new DecimalFormat("#.##"); System.out.println(df.format(100.1234)); // ...

  3. jmeter测试工具安装篇

    安装jmeter之前需要安装Java环境 window系统安装java 下载jdk 安装前我们需要下载java开发工具包JDK,下载地址:http://www.oracle.com/technetwo ...

  4. 关于osqp

    看了osqp的英文概要,记录如下: 1.采用交替方向乘子法 2.通过因式分解高速缓冲和热启动可以减少运算时间 3.适合嵌入式系统,实测mpc在10ms之内,路径规划在20ms左右(少障碍物),障碍物多 ...

  5. Python 面试题整理

    一.语言特性 1.什么是Python?使用Python有什么好处?Python和其他语言的区别? Python是一种编程语言,它有对象,模块,线程,异常处理和自动内存管理. 好处:开源.简洁.简单.方 ...

  6. 关闭 Microsoft Compatibility Telemetry

    Microsoft Compatibility Telemetry可能会导致操作系统(Win10)启动后一直读盘,打开任务管理器可能会看到 Microsoft Compatibility Teleme ...

  7. @EnableAspectJAutoProxy 注解的作用 —— 转载

    @EnableAspectJAutoProxy(proxyTargetClass = true, exposeProxy = true)解决同类方法调用时异步和事务不生效:我们在开启springboo ...

  8. EPLAN部件库汇总贴转

    经常看到网友求EPLAN部件库,授人以鱼不如授人以渔,大可不必把所有部件装上,比如软件自带的部件库,我都弃之不用,新建一个部件库,把工作中经常要用到的部件慢慢添加进去.慢慢的你会发现:画图效率越来越高 ...

  9. 整合mybatis-示例

    引入依赖 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.o ...

  10. P1067 [NOIP2009 普及组] 多项式输出 题解

    目录 题目 要注意的地方 code 题目 P1067 [NOIP2009 普及组] 多项式输出 要注意的地方 是不是常数项 是不是1 或 -1 输入的是不是第一个 ^1 负数 code #includ ...