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. Python基础『一』

    内置数据类型 数据名称 例子 数字: Bool,Complex,Float,Integer True/False; z=a+bj; 1.23; 123 字符串: String '123456' 元组: ...

  2. Scrapy爬虫-win7下创建运行项目

    开始的时候,我只安装了python3.5,安装不了scrapy库,网上搜了一下说是scrapy不支持python3.x 然后,我就又安装了python2.7 为了,默认使用2.7,我在环境变量path ...

  3. tensorflow lite 之生成 tflite 模型文件

    下载最新的的tensorflow源码. 1.配置 tflite 文件转换所需环境 安装 bazel 编译工具 https://docs.bazel.build/versions/master/inst ...

  4. shell习题第13题:监控nginx进程

    [题目要求] 在服务器上写一个脚本,要求如下 1. 每隔10秒去检查而一次服务器上的nginx进程数,如果>=500的时候,就需要自动重启一下nginx服务,并检测启动是否成功 2. 如没有正常 ...

  5. MyBatis Java不同方式加载文件时的路径格式问题、Mybatis中加载.properties文件

    public class LoadPropTest { public static void main(String[] args) throws IOException { //一.Properti ...

  6. 阿里云 负载均衡 HTTP转HTTPS

    一.相关文档 1.证书服务 2.简单路由-HTTP 协议变为 HTTPS 协议 二.阿里云操作界面 1.云盾证书服务管理控制台(查询CA证书服务) 2.负载均衡管理控制台 三.相关文档 1.Syman ...

  7. 选项卡TAB

    一.基础信息 关键class名:nav 写法: (1)头部选中状态:class="active" (2)头部按钮进行切换:<a>加data-toggle="t ...

  8. ORACLE触发器的自治事务的注意事项

    直接上代码: Create OR replace Trigger TR_ROBXMX_CLDJBHHX After INSERT OR UPDATE OR DELETE ON ROBXMX1 --要监 ...

  9. Advanced Installer 安装完成后,自动启动主程序。

    这个耗时2天,才研究测试通过.一定要记住了方法: =========================================================================== ...

  10. 14 Django之Form和Model Form组件

    一.什么是Form 我们之前在HTML页面中利用form表单向后端提交数据时,都会写一些获取用户输入的标签并且用form标签把它们包起来. 与此同时我们在好多场景下都需要对用户的输入做校验,比如校验用 ...