博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CF 49E Common ancestor
阅读量:6220 次
发布时间:2019-06-21

本文共 1364 字,大约阅读时间需要 4 分钟。

模拟赛T1就自闭了(

才不会说我是去刚T2了来着

感觉非常暴力的一个题?

出题人良心开大数据范围 n=100 还是原来的n^4*26算法我也是自闭了

不过貌似跑不到n^4?

真·大力出奇迹

一发记忆化搜索 就是f[l][r][c]表示 l~r化成一个字符c是否可行

然后大力出奇迹!= =+

枚举一下i,j表示第一个字符串的前i个和第二个字符串前j个合成的最短ancestor长度

再枚举从哪个开始合并

判一下就好啦

太真实了。谁敢写这种东西嘛= =+

【本来以为全场A的后来好像也只有4个人A?最后10min30爆搜一次写对还是很开心的= =+】

#include
#include
#include
#include
#define inf 20021225#define ll long longusing namespace std;int n,l1,l2;char s1[110],s2[110],fr[110][2],to[110][3];int f1[110][110][27],f2[110][110][27];int id(char ch){return ch-'a'+1;}int dfs(char *ch,int f[][110][27],char goal,int l,int r){ if(r
'z') fr[i][0]=getchar(); to[i][0]=getchar(); while(to[i][0]<'a'||to[i][0]>'z') to[i][0]=getchar(); to[i][1]=getchar(); //printf("%s %s",fr[i],to[i]); } memset(f1,-1,sizeof(f1)); memset(f2,-1,sizeof(f2)); memset(fin,48,sizeof(fin)); fin[0][0]=0; for(int i=1;i<=l1;i++) for(int j=1;j<=l2;j++) for(int k1=1;k1<=i;k1++) for(int k2=1;k2<=j;k2++) { int pp; if(fin[k1-1][k2-1]==fin[101][101]) continue; for(pp=0;pp<26;pp++) if(dfs(s1,f1,pp+'a',k1,i) && dfs(s2,f2,pp+'a',k2,j)) break; if(pp<26) fin[i][j]=min(fin[i][j],fin[k1-1][k2-1]+1); } printf("%d\n",fin[l1][l2]==fin[101][101]?-1:fin[l1][l2]); return 0;}/**ababaaba2c->bac->cc*/

我的码风怎么越来越奇怪了= =||

转载于:https://www.cnblogs.com/hanyuweining/p/10321931.html

你可能感兴趣的文章
深挖android low memory killer
查看>>
Linux_CentOS-服务器搭建 <一>
查看>>
mybatis3.2.6整合spring4.0和springMVC4.0开发
查看>>
浅谈C之精华---指针
查看>>
主备不一致:Table definition on master and slave does not match
查看>>
通过JVM日志来进行安全点分析
查看>>
Linux makefile 教程 非常详细,且易懂
查看>>
cgroup (Control Groups)
查看>>
我的 Android 开发实战经验总结
查看>>
centos 7.4 nodejs docker+node环境准备
查看>>
数据监听
查看>>
基于Laravel的轻量级CMS系统及通用管理后台
查看>>
跳动在网页之间的精灵——JavaScript
查看>>
GT - iOS性能分析工具 - 集成使用
查看>>
Slog93_使用React框架进行前端开发5
查看>>
vagrant box add metadata.json报错
查看>>
Swift Currying(柯里化)
查看>>
Java 泛型原理
查看>>
支持cocoapods
查看>>
为什么说传统分布式事务不再适用于微服务架构?
查看>>