1055: [HAOI2008]玩具取名

Time Limit: 10 Sec  Memory Limit: 162 MB
Submit: 1560  Solved: 907
[Submit][Status][Discuss]

Description

  某人有一套玩具,并想法给玩具命名。首先他选择WING四个字母中的任意一个字母作为玩具的基本名字。然后他会根据自己的喜好,将名字中任意一个字母用“WING”中任意两个字母代替,使得自己的名字能够扩充得很长。现在,他想请你猜猜某一个很长的名字,最初可能是由哪几个字母变形过来的。

Input

  第一行四个整数W、I、N、G。表示每一个字母能由几种两个字母所替代。接下来W行,每行两个字母,表示W可以用这两个字母替代。接下来I行,每行两个字母,表示I可以用这两个字母替代。接下来N行,每行两个字母,表示N可以用这两个字母替代。接下来G行,每行两个字母,表示G可以用这两个字母替代。最后一行一个长度不超过Len的字符串。表示这个玩具的名字。

Output

  一行字符串,该名字可能由哪些字母变形而得到。(按照WING的顺序输出)如果给的名字不能由任何一个字母变形而得到则输出“The name is wrong!”

Sample Input

1 1 1 1
II
WW
WW
IG
IIII

Sample Output

IN

HINT

W可以变成II所以IIII可以缩成WW IN均能变成WW所以WW又可以缩成I或者N 所以最终答案应该按照“WING”的顺序
输出IN 
[数据范围]
100%数据满足Len<=200,W、I、N、G<=16

Source

Solution

区间DP

暴力转移就可以...就是比人家慢个10多倍罢了

f[l][r][k]表示[l,r]是否能压成k

然后枚举区间长度,枚举左端点,枚举WING,枚举WING的每种缩,枚举断点

总之就是暴力转移,然后就可以了

Code

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<cstring>
#include<map>
using namespace std;
char s[][][],S[],N[],c[];
map<char,int>mp;
bool f[][][];
int main()
{
scanf("%d%d%d%d",&N[],&N[],&N[],&N[]);
mp['W']=,mp['I']=,mp['N']=,mp['G']=;
c[]='W',c[]='I',c[]='N',c[]='G';
for (int i=; i<=; i++)
for (int j=; j<=N[i]; j++)
scanf("%s",s[i][j]+);
scanf("%s",S+); int len=strlen(S+);
for (int i=; i<=len; i++) f[i][i][mp[S[i]]]=;
for (int i=; i<=len; i++)
for (int j=; j<=len; j++)
if (j+i-<=len)
{
int L=j,R=j+i-;
for (int k=; k<=; k++)
for (int l=; l<=N[k]; l++)
for (int m=L; m<R; m++)
f[L][R][k]|=(f[L][m][ mp[ s[k][l][] ]] & f[m+][R][ mp[ s[k][l][] ]]);
}
for (int i=; i<=; i++) if (f[][len][i]) putchar(c[i]);
if (!f[][len][] && !f[][len][] && !f[][len][] && !f[][len][]) puts("The name is wrong!");
return ;
}

最新文章

  1. 正确使用ng-if和ng-show
  2. 常用正则表达式大全!(例如:匹配中文、匹配html)
  3. Theano3.3-练习之逻辑回归
  4. Tomcat+eclipse JSP windows开发环境配置
  5. 德州扑克AI实现 TexasHoldem Poker
  6. 转:Python itertools模块
  7. mac下批量删除.svn文件
  8. java笔记15之this
  9. AR/VR行业是否会像智能手机一样的飞速崛起
  10. WP8.1开发中ListView控件加载图列表的简单使用(1)
  11. 篇5 python自动化测试应用-Selenium环境篇
  12. mysql数据表最高速迁移,mysql的存储引擎为:myisam
  13. Git Log描述乱码问题解决方法
  14. Spring的核心接口
  15. [Swift]LeetCode302. 包含黑色像素的最小矩形 $ Smallest Rectangle Enclosing Black Pixels
  16. selenium--键盘事件
  17. WPF保存包含Winform控件的XAML页面问题
  18. C# using 的用法
  19. fiddler抓取手机上https数据失败,全部显示“Tunnel to......443”解决办法
  20. 因微信SSJD分享接口升级,分享变化

热门文章

  1. CSS3 perspecitve属性
  2. [py]shell着色
  3. java 中的异步回调
  4. Matlab画图,坐标轴范围设置和间隔设置
  5. Webservice学习
  6. ubuntu-16.4TLS安装QQ
  7. Vmware player 12
  8. python代码缩进
  9. 【摘抄】将xml注释文档生成网页
  10. 【BZOJ 1875】【SDOI 2009】HH去散步