Combine String HDU - 5707

  题目大意:给你三个串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 广搜的更多相关文章

  1. HDU 5652(二分+广搜)

    题目链接:http://acm.hust.edu.cn/vjudge/contest/128683#problem/E 题目大意:给定一只含有0和1的地图,0代表可以走的格子,1代表不能走的格 子.之 ...

  2. hdu 1175 连连看 (广搜,注意解题思维,简单)

    题目 解析见代码 #define _CRT_SECURE_NO_WARNINGS //这是非一般的最短路,所以广搜到的最短的路不一定是所要的路线 //所以应该把所有的路径都搜索出来,找到最短的转折数, ...

  3. hdu 1240(三维广搜)

    题意: 有一个n*n*n的三维空间. 给你起始坐标和终点坐标.要你从起点到终点,问最少需要多少步走出去.如果走不出去则输出"NO ROUTE". 空间中 'O' 表示这个点可以走, ...

  4. HDU 1253 (简单三维广搜) 胜利大逃亡

    奇葩!这么简单的广搜居然爆内存了,而且一直爆,一直爆,Orz 而且我也优化过了的啊,尼玛还是一直爆! 先把代码贴上睡觉去了,明天再来弄 //#define LOCAL #include <ios ...

  5. hdu 1495 非常可乐 (广搜)

    题目链接 Problem Description 大家一定觉的运动以后喝可乐是一件很惬意的事情,但是seeyou却不这么认为.因为每次当seeyou买了可乐以后,阿牛就要求和seeyou一起分享这一瓶 ...

  6. HDU 1072 Nightmare (广搜)

    题目链接 Problem Description Ignatius had a nightmare last night. He found himself in a labyrinth with a ...

  7. HDU 1242 Rescue (广搜)

    题目链接 Problem Description Angel was caught by the MOLIGPY! He was put in prison by Moligpy. The priso ...

  8. hdu Digital Square(广搜)

    题目:给出n,求出最小的m,满足m^2  % 10^k = n,其中k=0,1,2 http://acm.hdu.edu.cn/showproblem.php?pid=4394 只要有一个x满足条件便 ...

  9. 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 ...

随机推荐

  1. Creating mailbox file: 文件已存在

    原来linux下添加用户后,会在系统里自动加一个邮箱(系统邮箱),路径是:/var/spool/mail/用户名.可以直接用命令#rm -rf /var/spool/mail/用户名 这样就可以再次添 ...

  2. JSONObject,JSONArray,对象,数组互相转化

    json类型对象转化成对象类型 JSONObject.toJavaObject(jsonObj, Object.class) json类型对象转化为List类型 JSONArray.parseArra ...

  3. pat L2_004

    一棵二叉搜索树可被递归地定义为具有下列性质的二叉树:对于任一结点, 其左子树中所有结点的键值小于该结点的键值: 其右子树中所有结点的键值大于等于该结点的键值: 其左右子树都是二叉搜索树. 所谓二叉搜索 ...

  4. __imp__SetupDiDestroyDeviceInfoList

    error LINK2019 unresolved external symbol __imp__SetupDiDestroyDeviceInfoList 分类: 转载文章2012-11-02 15: ...

  5. JS 编程艺术

    JS艺术片段剪贴 getFullDate: function (date) { //返回 YYYY年MM月DD日 var year = month = day = ' '; if (isNaN(dat ...

  6. 根据CPU核心数确定线程池并发线程数(转)

    一.抛出问题 关于如何计算并发线程数,一般分两派,来自两本书,且都是好书,到底哪个是对的?问题追踪后,整理如下: 第一派:<Java Concurrency in Practice>即&l ...

  7. CDH5.16.1的kafka集群报错: No broker in ISR for partition [getngo_collect_apm_test,0]

    1 详细错误 kafka.common.NoReplicaOnlineException: No broker in ISR for partition [getngo_collect_apm_tes ...

  8. AJAX—JSON和Django内置序列化

    JSON 什么是JSON JSON 指的是 JavaScript 对象表示法(JavaScript Object Notation) JSON 是轻量级的文本数据交换格式 JSON 独立于语言 * J ...

  9. (二十三)ARM平台NEON指令的编译和优化

    ARM平台NEON指令的编译和优化 本文介绍了ARM平台基于ARM v7-A架构的ARM Cortex-A系列处理器(Cortex-A5, Cortex-A7,Cortex-A8, Cortex-A9 ...

  10. Struts2之jsp页面取得当前actionName

    在页面上加入<s:debug />, 我们就可以查看stackContext的信息 其中有一项:Key为com.opensymphony.xwork2.ActionContext.name ...