CF 49E Common ancestor
传送门
模拟赛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<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#define inf 20021225
#define ll long long
using 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<l) return 0;
if(~f[l][r][id(goal)]) return f[l][r][id(goal)];
if(l==r) return ch[l]==goal;
memset(f[l][r],0,sizeof(f[l][r]));
for(int i=1;i<=n;i++)
for(int k=l;k<r;k++)
if(dfs(ch,f,to[i][0],l,k)&&dfs(ch,f,to[i][1],k+1,r))
{
f[l][r][id(fr[i][0])]=1;break;
}
return f[l][r][id(goal)];
}
int fin[110][110];
int main()
{
scanf("%s%s",s1+1,s2+1);
l1=strlen(s1+1);l2=strlen(s2+1);
scanf("%d",&n);
int i;
for(i=1;i<=n;i++)
{
fr[i][0]=getchar();
while(fr[i][0]<'a'||fr[i][0]>'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;
}
/**
ababa
aba
2
c->ba
c->cc
*/
我的码风怎么越来越奇怪了= =||
CF 49E Common ancestor的更多相关文章
- [LeetCode] Lowest Common Ancestor of a Binary Tree 二叉树的最小共同父节点
Given a binary tree, find the lowest common ancestor (LCA) of two given nodes in the tree. According ...
- [LeetCode] Lowest Common Ancestor of a Binary Search Tree 二叉搜索树的最小共同父节点
Given a binary search tree (BST), find the lowest common ancestor (LCA) of two given nodes in the BS ...
- 48. 二叉树两结点的最低共同父结点(3种变种情况)[Get lowest common ancestor of binary tree]
[题目] 输入二叉树中的两个结点,输出这两个结点在数中最低的共同父结点. 二叉树的结点定义如下: C++ Code 123456 struct BinaryTreeNode { int ...
- [LeetCode]Lowest Common Ancestor of a Binary Search Tree
Given a binary search tree (BST), find the lowest common ancestor (LCA) of two given nodes in the BS ...
- 数据结构与算法(1)支线任务4——Lowest Common Ancestor of a Binary Tree
题目如下:https://leetcode.com/problems/lowest-common-ancestor-of-a-binary-tree/ Given a binary tree, fin ...
- Lowest Common Ancestor of a Binary Search Tree
Given a binary search tree (BST), find the lowest common ancestor (LCA) of two given nodes in the BS ...
- Lowest Common Ancestor of a Binary Tree
Given a binary tree, find the lowest common ancestor (LCA) of two given nodes in the tree. According ...
- leetcode 235. Lowest Common Ancestor of a Binary Search Tree
Given a binary search tree (BST), find the lowest common ancestor (LCA) of two given nodes in the BS ...
- leetcode 236. Lowest Common Ancestor of a Binary Tree
Given a binary tree, find the lowest common ancestor (LCA) of two given nodes in the tree. According ...
随机推荐
- Leetcode_132. Palindrome Partitioning II_[DP]
题目链接 Given a string s, partition s such that every substring of the partition is a palindrome. Retur ...
- [luogu]P1169 [ZJOI2007]棋盘制作[DP][单调栈]
[luogu]P1169 [ZJOI]棋盘制作 ——!x^n+y^n=z^n 题目描述 国际象棋是世界上最古老的博弈游戏之一,和中国的围棋.象棋以及日本的将棋同享盛名.据说国际象棋起源于易经的思想,棋 ...
- CSS入门基础学习二
我们下午继续学习CSS的入门基础,搬上你的小板凳赶快进入吧! 一.背景(background) Background-color:背景颜色 background-image (背景图片) backgr ...
- 【HDOJ6693】Valentine's Day(概率)
题意:给定n件物品,每件物品让周驿东开心的概率为a[i] 要求从中选一些,使得周驿东恰好开心一次的概率最大 n<=1e4,0<=a[i]<=1 思路: #include<bit ...
- Nginx 禁止IP访问 只允许域名访问
今天要在Nginx上设置禁止通过IP访问服务器,只能通过域名访问,这样做是为了避免别人把未备案的域名解析到自己的服务器IP而导致服务器被断网,从网络上搜到以下解决方案: Nginx的默认虚拟主机在用户 ...
- 实验吧 Web的WriteUp
每次看别人的Writeup都有一种感觉,为什么有了WriteUp我还是不会,每次都打击自己的积极性,所以自己尝试写一篇每个萌新都能看懂的Writeup. 0x01 天下武功唯快不破 题目提示 : 看看 ...
- Django 的工作流程和基本内容
1.一个基本的Django请求流程 我们先开始写一个基本的请求.这个请求的获取和处理,是使用 urls.py 和 views.py 处理的.我们使用命令 python manage.py runser ...
- 20190818 On Java8 第八章 复用
第八章 复用 组合语法 初始化引用有四种方法: 当对象被定义时.这意味着它们总是在调用构造函数之前初始化. 在该类的构造函数中. 在实际使用对象之前.这通常称为延迟初始化.在对象创建开销大且不需要每次 ...
- JPA Example查询
//创建查询条件数据对象 Customer customer = new Customer(); customer.setAddress("河南省郑州市"); customer.s ...
- [已解决]报错: warning: LF will be replaced by CRLF in lib/anime.min.js
git config --global core.autocrlf false