Bzoj 1055: [HAOI2008]玩具取名 (区间DP)
Bzoj 1055: [HAOI2008]玩具取名 (区间DP)
题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1055
区间动态规划和可达性DP的好题.
开始WA了几次,感到非常奇怪.
原因竟然是n被定义了char型,真是zz了.
\(f[i][j][k]\)表示区间\(i\)到\(j\)可以由\(k\)这个字符是否可以转变过来.
转移的时候枚举中间点转移就好了.
#include <iostream>
#include <cstring>
#include <cstdio>
const int maxN = 200 + 7;
using namespace std;
const char Q[] = {' ','W','I','N','G'};
bool f[maxN][maxN][5];
bool is_match[5][5][5];
int q[5];
char s[maxN],c[5];
inline int pd(char i){
if(i == Q[1]) return 1;
if(i == Q[2]) return 2;
if(i == Q[3]) return 3;
if(i == Q[4]) return 4;
}
int main() {
for(int i = 1;i <= 4;++ i)
scanf("%d",&q[i]);
for(int i = 1;i <= 4;++ i) {
for(int j = 1;j <= q[i];++ j) {
scanf("%s",c);
is_match[i][pd(c[0])][pd(c[1])] = true;
}
}
scanf("%s",s + 1);
int n = strlen(s + 1);
for(int i = 1;i <= n;++ i)
f[i][i][pd(s[i])] = true;
for(int leg = 1;leg < n;++ leg) {
for(int l = 1;l + leg <= n;++ l) {
int r = l + leg;
for(int k = l;k < r;++ k) {
for(int i = 1;i <= 4;++ i) { //枚举 l 到 r 的字符
for(int j = 1;j <= 4;++ j) {// 枚举l 到 k 的字符
for(int a = 1;a <= 4;++ a) { //枚举k + 1到r的字符
if(is_match[i][j][a]) {
if( f[l][k][j] && f[k + 1][r][a])
f[l][r][i] = 1;
}
}
}
}
}
}
}
bool flag = false;
for(int i = 1;i <= 4;++ i)
if(f[1][n][i]) flag = true,printf("%c",Q[i]);
if(!flag) puts("The name is wrong!");
return 0;
}
Bzoj 1055: [HAOI2008]玩具取名 (区间DP)的更多相关文章
- [BZOJ 1055][HAOI2008]玩具取名(DP)
题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=1055 分析: 比较难想的dp f[i][j][c]表示i..j能否压缩成字符c 那么怎 ...
- bzoj 1055 [HAOI2008]玩具取名(区间DP)
1055: [HAOI2008]玩具取名 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1258 Solved: 729[Submit][Statu ...
- BZOJ1055: [HAOI2008]玩具取名[区间DP]
1055: [HAOI2008]玩具取名 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1588 Solved: 925[Submit][Statu ...
- BZOJ 1055 [HAOI2008]玩具取名
1055: [HAOI2008]玩具取名 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1119 Solved: 653[Submit][Statu ...
- [BZOJ 1055] [HAOI2008] 玩具取名 【记忆化搜索】
题目链接:BZOJ - 1055 题目分析 这种类似区间 DP 的记忆化搜索都是很相近的,比如字符串压缩和字符串扩展都差不多. 都是将现在 Solve 的区间分成子区间,再求解子区间. 这道题 Sol ...
- [LUOGU] P4290 [BZOJ] 1055 [HAOI2008]玩具取名
题目描述 某人有一套玩具,并想法给玩具命名.首先他选择WING四个字母中的任意一个字母作为玩具的基本名字.然后他会根据自己的喜好,将名字中任意一个字母用"WING"中任意两个字母代 ...
- bzoj 1055: [HAOI2008]玩具取名【区间dp】
不难想,就是处理起来比较麻烦 设f[i][j][k]为是否可以把区间(i,j)合并为k,初始状态是f[i][j][s[i]]=1,转移的话另一段枚举长度x,向(i-x,j),(i,j+x)转移 把四个 ...
- 【BZOJ】1055: [HAOI2008]玩具取名(dp)
http://www.lydsy.com/JudgeOnline/problem.php?id=1055 我竟然都没往dp这个方向想.....百度了下看到标题是dp马上就会转移了QAQ... 设d[i ...
- BZOJ 1055: [HAOI2008]玩具取名(记忆化搜索)
http://www.lydsy.com/JudgeOnline/problem.php?id=1055 题意: 思路:记忆化搜索. #include<iostream> #include ...
随机推荐
- python 的 数据类型
数据类型 1.1整型int py2中有int有范围,超出自动转为long长整型,py3中只有int 整除py2中无小数,可加一行代码实现 十进制转二进制 print(bin(10))十进制转八进制 p ...
- 阿里云物联网 .NET Core 客户端 | CZGL.AliIoTClient:4.1 上报位置信息
文档目录: 说明 1. 连接阿里云物联网 2. IoT 客户端 3. 订阅Topic与响应Topic 4. 设备上报属性 4.1 上报位置信息 5. 设置设备属性 6. 设备事件上报 7. 服务调用 ...
- APP上传
原文网址: http://blog.csdn.net/ayangcool 前言:作为一名IOS开发者,把开发出来的App上传到App Store是必须的.下面就来详细介绍下具体流程. 1.打开苹果开发 ...
- 最简大数据Spark-2.1.0
0.0 前言 本文主要基于最新的Spark 2.1.0版本.阅读本文可以对Spark 2.1.0的学习过程,运行流程,关键组件,原理有所了解.文章有点长,你也可以直接阅读感兴趣的部分,但是还是建议全面 ...
- idea下载
- javascript 数组、json连接
json(或数组).concat(需要添加的json(或数组))
- layer窗口抖动
详细学习网址 http://www.layui.com/doc/modules/layer.html#use ..................................... //使用方法 ...
- HTML <form> 标签的 enctype
form的enctype有三种 application/x-www-form-urlencoded 在发送前编码所有字符(默认) multipart/form-data 不对字符编码. 在使用包含文件 ...
- 从零开始利用vue-cli搭建简单音乐网站(二)
1.利用vue-router实现页面跳转 程序可以正常运行之后,下面我们需要配置路由实现页面的局部刷新,这一功能将用来实现网站页面的跳转. 打开程序目录,进入"src\router\inde ...
- IDEA 启用/禁用 Run Dashboard
一.启用 方式一: 创建/打开一个SpringBoot项目[或者点击Run --> Edit Configurations 添加 Spring Boot 类型的项目配置:或者如图在红框处添加配置 ...