Combine String HDU - 5707 dp or 广搜
题目大意:给你三个串a,b,c,问a和b是不是恰好能组成c,也就是a,b是不是c的两个互补的子序列。
根据题意就可以知道对于c的第一个就应该是a第一个或者b的第一个,如果第一个是a的第一个,那么c的第二个就应该是a的第二个或者是b的第一个,反之也是一样的。那么我们定义dp[i][j]就是a串匹配到i位置,b串匹配到j位置的合理性,那么dp[i][j]就由dp[i-1][j]和dp[i][j-1]推过来,a串匹配到i位置,b串匹配到j位置,那么c串就匹配到了i+j位置,然后判断是否匹配即可。
#include<cstdio>
#include<cstring>
const int N=;
bool dp[N][N];
char a[N],b[N],c[N];
int main()
{
while(~scanf("%s",a+))
{
scanf("%s",b+);
scanf("%s",c+);
int lena=strlen(a+),lenb=strlen(b+),lenc=strlen(c+);
if(lena+lenb!=lenc)//c的长度肯定得是等于a和b之和
{
printf("No\n");
continue;
}
for(int i=;i<=lena;i++)
for(int j=;j<=lenb;j++)
dp[i][j]=false;
dp[][]=true;
for(int i=;i<=lena;i++)
for(int j=;j<=lenb;j++)
{
if(i)
dp[i][j]|=(dp[i-][j]&&a[i]==c[i+j]);
if(j)
dp[i][j]|=(dp[i][j-]&&b[j]==c[i+j]);
}
if(dp[lena][lenb])
printf("Yes\n");
else
printf("No\n");
}
return ;
}
dpdpdpd
一开始觉得像搜索,所以也是先写了广搜,转移过程一样。
#include<cstdio>
#include<queue>
#include<cstring>
using namespace std;
const int N=;
struct Node{
int i,j,k;
Node(){}
Node(int i,int j,int k):i(i),j(j),k(k){}
}p;
char a[N],b[N],c[N];
int flag,lena,lenb,lenc;
bool vis[N][N];
void bfs()
{
for(int i=;i<=lena;i++)
for(int j=;j<=lenb;j++)
vis[i][j]=;
flag=;
queue<Node> q;
q.push(Node(,,));
while(!q.empty())
{
p=q.front();
q.pop();
if(p.i==lena&&p.j==lenb&&p.k==lenc)
{
flag=;
return ;
}
if(p.i+<=lena&&p.k+<=lenc&&a[p.i+]==c[p.k+]&&!vis[p.i+][p.j])
{
vis[p.i+][p.j]=;
q.push(Node(p.i+,p.j,p.k+));
}
if(p.j+<=lenb&&p.k+<=lenc&&b[p.j+]==c[p.k+]&&!vis[p.i][p.j+])
{
vis[p.i][p.j+]=;
q.push(Node(p.i,p.j+,p.k+));
}
}
}
int main()
{
while(~scanf("%s",a+))
{
scanf("%s",b+);
scanf("%s",c+);
lena=strlen(a+);
lenb=strlen(b+);
lenc=strlen(c+);
if(lena+lenb!=lenc)
{
printf("No\n");
continue;
}
bfs();
if(flag)
printf("Yes\n");
else
printf("No\n");
}
return ;
}
搜索搜索搜索
Combine String HDU - 5707 dp or 广搜的更多相关文章
- HDU 5652(二分+广搜)
题目链接:http://acm.hust.edu.cn/vjudge/contest/128683#problem/E 题目大意:给定一只含有0和1的地图,0代表可以走的格子,1代表不能走的格 子.之 ...
- hdu 1175 连连看 (广搜,注意解题思维,简单)
题目 解析见代码 #define _CRT_SECURE_NO_WARNINGS //这是非一般的最短路,所以广搜到的最短的路不一定是所要的路线 //所以应该把所有的路径都搜索出来,找到最短的转折数, ...
- hdu 1240(三维广搜)
题意: 有一个n*n*n的三维空间. 给你起始坐标和终点坐标.要你从起点到终点,问最少需要多少步走出去.如果走不出去则输出"NO ROUTE". 空间中 'O' 表示这个点可以走, ...
- HDU 1253 (简单三维广搜) 胜利大逃亡
奇葩!这么简单的广搜居然爆内存了,而且一直爆,一直爆,Orz 而且我也优化过了的啊,尼玛还是一直爆! 先把代码贴上睡觉去了,明天再来弄 //#define LOCAL #include <ios ...
- hdu 1495 非常可乐 (广搜)
题目链接 Problem Description 大家一定觉的运动以后喝可乐是一件很惬意的事情,但是seeyou却不这么认为.因为每次当seeyou买了可乐以后,阿牛就要求和seeyou一起分享这一瓶 ...
- HDU 1072 Nightmare (广搜)
题目链接 Problem Description Ignatius had a nightmare last night. He found himself in a labyrinth with a ...
- HDU 1242 Rescue (广搜)
题目链接 Problem Description Angel was caught by the MOLIGPY! He was put in prison by Moligpy. The priso ...
- hdu Digital Square(广搜)
题目:给出n,求出最小的m,满足m^2 % 10^k = n,其中k=0,1,2 http://acm.hdu.edu.cn/showproblem.php?pid=4394 只要有一个x满足条件便 ...
- HDU - 3345 War Chess 广搜+优先队列
War chess is hh's favorite game: In this game, there is an N * M battle map, and every player has hi ...
随机推荐
- Creating mailbox file: 文件已存在
原来linux下添加用户后,会在系统里自动加一个邮箱(系统邮箱),路径是:/var/spool/mail/用户名.可以直接用命令#rm -rf /var/spool/mail/用户名 这样就可以再次添 ...
- 【思维】ABC
题目描述 You are given a string s consisting of A, B and C.Snuke wants to perform the following operatio ...
- django+uwsgi+nginx: websock 报502/400
耽搁了近2个月,终于解决了,主要是nginx/uwsgi/django相关的配置: 一.django工程settings.py,添加 WEBSOCKET_FACTORY_CLASS = "d ...
- [转载]目标检测-Selective Search
[转载]目标检测-Selective Search 转载纯粹是因为这篇写的很好,mark一下: https://zhuanlan.zhihu.com/p/27467369
- octave 笔记
1. 画函数 >> x = [-4:0.5:6] >> y = x.^2 - x - 6 >> plot(y)
- spark application调度机制(spreadOutApps,oneExecutorPerWorker 算法)
1.要想明白spark application调度机制,需要回答一下几个问题: 1.谁来调度? 2.为谁调度? 3.调度什么? 3.何时调度? 4.调度算法 前四个问题可以用如下一句话里来回答:每当集 ...
- 对于div里面内容过大根据长度或者宽度进行适配,然后可以滚轮缩放的功能
在做3000的项目中,因为页面的svg很大,但是做的只是适配电脑,打开肯定是看不全的,要看全就必须进行滚动,可是客户提出了将页面放在电视机上面,用电视输入网址直接访问,这样问题就来了,电视上怎么进行滚 ...
- 用Leangoo看板进行可视化的缺陷跟踪管理
转自:https://www.leangoo.com/10464.html 缺陷管理通常关注如下几个方面: 1. 缺陷的处理速度 2. 缺陷处理的状态 3. 缺陷的分布 4. 缺陷产生的原因 使用Le ...
- linux之getopts
在编写shell脚本中,经常要处理一些输入参数,在使用过程中发现getopts更加方便,能够很好的处理用户输入的参数和参数值. getopts用于处理用户输入参数,举例说明使用方法: while ge ...
- Short XSS
Short XSS Crackkay · 2013/08/21 12:17 0x00 背景 关键时候长度不够怎么办? 在实际的情况中如果你不够长怎么办呢?看医生?吃药?做手术?............ ...