BZOJ 4032 trie树+各种乱搞
思路 :
先对b 的所有后缀建立trie树
第一问
暴力枚举a串的起点
在trie树上跑 找到最短的
第二问
也是暴力枚举a串的起点
a和b顺着暴力匹配就好
第三问
求出来a在第i个位置 加一个字母j 能够到的最近的位置 f[i][j] 到最后就是inf
从f[0][j]DFS 在trie上跟着跑找到最小的deep更新答案
第四问
先按照求f一样同理求出b串 的 g
dp[i][j]表示a的前i个位置 b不得不匹配到b的第j个位置
dp[i+1][j]=min(dp[i+1][j],dp[i][j]), dp[i+1][g[j][a[i]]]=min(dp[i+1][g[j][a[i]]],dp[i][j]+1);//By SiriusRen
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
const int N=,inf=;
int ch[N*N/][],f[N][],g[N][],dp[N][N],cnt,ans1,ans2,ans3,ans4,vis[];
void insert(char *a){
int now=;
for(int i=;a[i];i++){
if(!ch[now][a[i]])ch[now][a[i]]=++cnt;
now=ch[now][a[i]];
}
}
int solve1(char *a){
int now=,i;
for(i=;a[i];i++){
if(!ch[now][a[i]])return i+;
else now=ch[now][a[i]];
}return inf;
}
void solve3(int x,int now,int deep){
if(x==inf)return;
if(!now&&deep){ans3=min(ans3,deep);return;}
for(int i=;i<=;i++)solve3(f[x][i],ch[now][i],deep+);
}
char a[N],b[N];
int main(){
scanf("%s%s",a+,b+);
int n1=strlen(a+),n2=strlen(b+);
for(int i=;i<=n1;i++)a[i]=a[i]-'a'+;
for(int i=;i<=n2;i++)b[i]=b[i]-'a'+;
for(int i=;i<=n2;i++)insert(b+i);
ans1=ans2=ans3=ans4=inf;
for(int i=;i<=n1;i++)ans1=min(ans1,solve1(a+i));
for(int i=;i<=n1;i++){
int now=;
for(int j=;i+j<=n1;now++,j++){
while(a[i+j]!=b[now]&&now<=n2)now++;
if(now>n2){ans2=min(ans2,j+);break;}
}
}
for(int i=;i<=n1;i++){
memset(vis,,sizeof(vis));
for(int j=i+;j<=n1;j++)if(!vis[a[j]])vis[a[j]]=j;
for(int j=;j<=;j++)f[i][j]=vis[j]?vis[j]:inf;
}solve3(,,);
for(int i=;i<=n2;i++){
memset(vis,,sizeof(vis));
for(int j=i+;j<=n2;j++)if(!vis[b[j]])vis[b[j]]=j;
for(int j=;j<=;j++)g[i][j]=vis[j]?vis[j]:inf;
}
memset(dp,0x3f,sizeof(dp)),dp[][]=;
for(int i=;i<=n1;i++)
for(int j=;j<=n2;j++)
dp[i+][j]=min(dp[i+][j],dp[i][j]),
dp[i+][g[j][a[i]]]=min(dp[i+][g[j][a[i]]],dp[i][j]+);
for(int i=;i<=n1+;i++)ans4=min(ans4,dp[i][inf]);
printf("%d\n%d\n%d\n%d\n",ans1==inf?-:ans1,ans2==inf?-:ans2,ans3==inf?-:ans3,ans4==inf?-:ans4);
}
BZOJ 4032 trie树+各种乱搞的更多相关文章
- BZOJ-3225 立方体覆盖 线段树+扫描线+乱搞
看数据范围像是个暴力,而且理论复杂度似乎可行,然后被卡了两个点...然后来了个乱搞的线段树+扫描线.. 3225: [Sdoi2008]立方体覆盖 Time Limit: 2 Sec Memory L ...
- [NOIP2018]:旅行(数据加强版)(基环树+搜索+乱搞)
题目描述 小$Y$是一个爱好旅行的$OIer$.她来到$X$国,打算将各个城市都玩一遍.小$Y$了解到,$X$国的$n$个城市之间有$m$条双向道路.每条双向道路连接两个城市.不存在两条连接同一对城市 ...
- BZOJ 4260 trie树
思路: 搞一个前缀异或和 一次从左往右 另一次从右往左 异或最大值 用字典树搞一搞 //By SiriusRen #include <cstdio> #include <cstrin ...
- BZOJ 2251 Trie树
思路: i~n加到Trie树里 经过的边权+1 DFS一遍 搞定~ //By SiriusRen #include <cstdio> #include <cstring> #i ...
- [luoguP2325] [SCOI2005]王室联邦(树分块乱搞)
传送门 想了半小时,没什么思路.. 看了题解,是个叫做树分块的奇奇怪怪的操作.. 题解 树分块的研究 #include <cstdio> #include <cstring> ...
- 【BZOJ】2456 mode(乱搞)
Description 给你一个n个数的数列,其中某个数出现了超过n div 2次即众数,请你找出那个数. Input 第1行一个正整数n.第2行n个正整数用空格隔开. Output 一行一个正整数表 ...
- bzoj 4900 [CTSC2017]密钥 模拟+乱搞
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4900 #include<cstring> #include<cmath&g ...
- 【BZOJ-4523】路由表 Trie树 + 乱搞
4523: [Cqoi2016]路由表 Time Limit: 30 Sec Memory Limit: 512 MBSubmit: 155 Solved: 98[Submit][Status][ ...
- Bzoj 1926: [Sdoi2010]粟粟的书架(二分答案+乱搞+主席树)
1926: [Sdoi2010]粟粟的书架 Time Limit: 30 Sec Memory Limit: 552 MB Description 幸福幼儿园 B29 班的粟粟是一个聪明机灵.乖巧可爱 ...
随机推荐
- VTK嵌入MFC同步显示
使用VTK嵌入MFC,实现四视图更新,机制和细节参考原文. 原文链接:http://blog.csdn.net/www_doling_net/article/details/8939115 原文代码: ...
- mysql 统计按天、星期、按月数据的各种 sql 语句 (转录)
文章主要是作为知识整理,内容略有修改,方便以后查阅,内容转摘至 陈宇衡的个人博客,欢迎前去围观. 作为演示效果,先创建一个测试表,在插入两条数据(注:时间为 datetime 类型,unix 时间戳需 ...
- js document 触发按键事件
// 键盘控制 var keyEvent = (function () { document.onkeydown = function (e) { if (e.keyCode === 38) { // ...
- Python之CSV模块
1. CSV简介 CSV(Comma Separated Values)是逗号分隔符文本格式,常用于Excel和数据库的导入和导出,Python标准库的CSV模块提供了读取和写入CSV格式文件的对象. ...
- 天翼云 RDS数据库操作
1.RDS数据库创建好之后点击RDS实例管理找到已下信息 官方文档 -1:http://www.ctyun.cn/help/qslist/567 官方文档 -2:http://www.ctyun.cn ...
- 05.Python高级编程
1 ==,is的使用 is 是比较两个引用是否指向了同一个对象(地址引用比较). == 是比较两个对象是否相等.(比较的数值) 2 深拷贝.浅拷贝.copy.copy 2.1 浅拷贝 浅拷贝: 拷贝的 ...
- 一维数组快速转集合(List)
String[] arr={"qwe","asd","zxc","asddf","hghgf"}; ...
- 0123简单配置LNMP
简单配置LNMP不怕出现错误,就怕错误不知道出现在哪里?看日值tail -f /var/log/message -- 系统整个的日志tail -f /var/log/nginx/error.log - ...
- java.lang.AbstractMethodError: org.apache.xerces.dom.DocumentImpl.getXmlStandalone()Z解决办法
2019-05-20 23:02:20.168 |-INFO [http-nio-8001-exec-2] com.xxx.ecc.cloudbiz.service.payment.impl.Wei ...
- SpringBoot支持AJAX跨域请求
利用注解的方式解决AJAX请求跨域问题 1.编写一个支持跨域请求的 Configuration - 第一种方式 - CorsConfig.java import org.springframework ...