玩具取名 bzoj-1055 HAOI-2008

题目大意:给你一个用W,I,N,G组成的字符串,给你一些这四个字符之间的变换规则,每一个变换规则都是由一个字符变成两个字符,问这个字符串是否可能是由一个单独的字符变成的。

注释:$1\le Len\le 200$,每种字符的变换规则<=16

想法:刚看见题以为又是什么单词接龙之类的题,然后看了一眼数据范围... ...还是不会。

查了题解,发现是一个挺不常见的bool区间dp

状态:dp[i][j][c]表示[i,j]这段区间是否能变成c字符,c是W,I,N,G中的一个。

转移:dp[i][j][c]=dp[i][k][c1]|dp[k+1][j][c2]&&c1和c2能合成c。

时间复杂度:$O(Len^3\cdot 16)$。

最后,附上丑陋的代码... ...

#include <iostream>
#include <cstring>
#include <cstdio>
using namespace std;
#define MAXN 205
int W,I,N,G,n,cnt;
char s[MAXN];
struct hp{char x,y,z;}ch[MAXN];
bool f[MAXN][MAXN][100];
int main()
{
scanf("%d%d%d%d\n",&W,&I,&N,&G);
for (int i=1;i<=W;++i) gets(s),ch[++cnt].x=s[0],ch[cnt].y=s[1],ch[cnt].z='W';
for (int i=1;i<=I;++i) gets(s),ch[++cnt].x=s[0],ch[cnt].y=s[1],ch[cnt].z='I';
for (int i=1;i<=N;++i) gets(s),ch[++cnt].x=s[0],ch[cnt].y=s[1],ch[cnt].z='N';
for (int i=1;i<=G;++i) gets(s),ch[++cnt].x=s[0],ch[cnt].y=s[1],ch[cnt].z='G';
gets(s);n=strlen(s);
for (int i=n;i>=1;--i) s[i]=s[i-1]; for (int i=1;i<=n;++i) f[i][i][s[i]]=true;
for (int len=2;len<=n;++len)
for (int l=1;l<=n-len+1;++l)
{
int r=l+len-1;
for (int k=l;k<=r;++k)
for (int i=1;i<=cnt;++i)
f[l][r][ch[i].z]|=f[l][k][ch[i].x]&&f[k+1][r][ch[i].y];
}
bool flag=false;
if (f[1][n]['W']) putchar('W'),flag=true;
if (f[1][n]['I']) putchar('I'),flag=true;
if (f[1][n]['N']) putchar('N'),flag=true;
if (f[1][n]['G']) putchar('G'),flag=true;
if (!flag) puts("The name is wrong!");
else putchar('\n');
}

小结:有的时候从数据范围入手猜时间复杂度,从时间复杂度入手解题,是很方便的。

[bzoj1055][HAOI2008]玩具取名_区间dp的更多相关文章

  1. BZOJ1055[HAOI2008]玩具取名 【区间dp + 记忆化搜索】

    题目 某人有一套玩具,并想法给玩具命名.首先他选择WING四个字母中的任意一个字母作为玩具的基本名字.然后 他会根据自己的喜好,将名字中任意一个字母用“WING”中任意两个字母代替,使得自己的名字能够 ...

  2. 【BZOJ1055】[HAOI2008]玩具取名(区间DP)

    [HAOI2008]玩具取名 题目描述 某人有一套玩具,并想法给玩具命名.首先他选择\(WING\)四个字母中的任意一个字母作为玩具的基本名字.然后他会根据自己的喜好,将名字中任意一个字母用" ...

  3. bzoj 1055 [HAOI2008]玩具取名(区间DP)

    1055: [HAOI2008]玩具取名 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1258  Solved: 729[Submit][Statu ...

  4. 1055. [HAOI2008]玩具取名【区间DP】

    Description 某人有一套玩具,并想法给玩具命名.首先他选择WING四个字母中的任意一个字母作为玩具的基本名字.然后 他会根据自己的喜好,将名字中任意一个字母用“WING”中任意两个字母代替, ...

  5. bzoj 1055: [HAOI2008]玩具取名【区间dp】

    不难想,就是处理起来比较麻烦 设f[i][j][k]为是否可以把区间(i,j)合并为k,初始状态是f[i][j][s[i]]=1,转移的话另一段枚举长度x,向(i-x,j),(i,j+x)转移 把四个 ...

  6. BZOJ1055: [HAOI2008]玩具取名[区间DP]

    1055: [HAOI2008]玩具取名 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1588  Solved: 925[Submit][Statu ...

  7. bzoj1055: [HAOI2008]玩具取名(dp)

    1055: [HAOI2008]玩具取名 题目:传送门 简要题意: 就是固定四个字母,给出这四个字母分别可以由哪两个字母组成,然后在给你一个字符串,要求把这个字符串还原成原始的四个字母的其中一个. 题 ...

  8. bzoj千题计划199:bzoj1055: [HAOI2008]玩具取名

    http://www.lydsy.com/JudgeOnline/problem.php?id=1055 区间DP dp[i][j][k] 表示区间[i,j]能否合成k #include<cst ...

  9. BZOJ1055: [HAOI2008]玩具取名

    ... #include<bits/stdc++.h> using namespace std; int q[255]; char s[205]; char p[]={'W','I','N ...

随机推荐

  1. C++模板(菜鸟教程)

    C++模板(菜鸟教程) C++ 模板 模板是泛型编程的基础,泛型编程即以一种独立于任何特定类型的方式编写代码. 模板是创建泛型类或函数的蓝图或公式.库容器,比如迭代器和算法,都是泛型编程的例子,它们都 ...

  2. ES transport client使用

    ES transport client bulk insert 传输(transport)客户端 TransportClient利用transport模块远程连接一个elasticsearch集群.它 ...

  3. node.js怎么配置访问本地的html文件?

    node.js怎么配置访问本地的html文件? https://segmentfault.com/q/1010000000251204

  4. [Apple开发者帐户帮助]四、管理密钥(3)撤消,编辑和下载密钥

    创建密钥后,您可以撤消,编辑或下载密钥.您只能下载一次密钥.私钥在iOS,tvOS和watchOS上的应用程序之间共享. 所需角色:帐户持有人或管理员. 撤销密钥 如果撤消密钥,它将变为无效并影响使用 ...

  5. JavaScript 进阶 常用内置对象

    一.常用内置对象 所谓内置对象就是ECMAscript提供出来的一些对象,我们知道对象都是有相应的属性和方法 数组Arry 1.数组的创建方式 字面量方式创建(推荐使用,简单粗暴) var color ...

  6. 最小生成树之Prim算法(最原始最详细入门)

    //算法6.8 普里姆算法 #include <iostream> using namespace std; typedef char VerTexType; typedef int Ar ...

  7. linux下常用命令失效

    注意:修改一下PATH环境变量 export PATH=/bin:/usr/bin/:. 可以把这句话加到你的.profile或者.bash_profile里,这样每次登录的时候都会生效

  8. Unity引擎GUI之Input Field

    InputField 文本输入组件,本文练习InputField的属性及事件 一.属性 1 Interactable: 是否禁用 Transition:过渡方式 Normal Color 正常的未有任 ...

  9. 【Oracle】redo与undo

    一 .redo(重做信息) 是Oracle在线(或归档)重做日志文件中记录的信息,万一出现失败时可以利用这些数据来“重放”(或重做)事务.Oracle中记录这些信息的文件叫做redo log file ...

  10. (转)Jetty实战之 安装 运行 部署

    http://blog.csdn.net/kongxx/article/details/7218767 本文地址:http://blog.csdn.NET/kongxx/article/details ...