bzoj1055
不难想到是一个布尔型dp,
不难想到用f[i,j,k]表示区间[i,j]能否变为字母k
不难想到对于f[i,j,k],拆[i,j]成两个区间,然后穷举k的每一个变换来判断
感觉记忆化搜索写的比较顺,就写了记忆化
const a:array[..] of char=('W','I','N','G');
var b:array[..] of longint;
f:array[..,..,..] of integer;
w:array[..,..] of longint;
c:array[..] of longint;
l,i,j,k,e,n,m,p:longint;
flag:boolean;
s:string;
function exc(x:char):longint;
begin
if x='W' then exit()
else if x='I' then exit()
else if x='N' then exit()
else if x='G' then exit();
end;
function search(l,r,k:longint):integer;
var i,j,x1,x2:longint;
begin
if f[l,r,k]<> then exit(f[l,r,k]);
if l=r then
begin
f[l,l,b[l]]:=;
if k=b[l] then exit()
else begin
f[l,l,k]:=-;
exit(-);
end;
end;
for i:= to c[k] do
begin
x1:=(w[k,i]-) div +;
x2:=(w[k,i]-) mod +;
for j:=l to r- do
begin
if (search(l,j,x1)=) and (search(j+,r,x2)=) then
begin
f[l,r,k]:=;
exit();
end;
end;
end;
f[l,r,k]:=-;
exit(-);
end;
begin
for i:= to do
read(c[i]);
readln;
for i:= to do
for j:= to c[i] do
begin
readln(s);
p:=(exc(s[])-)*+exc(s[]);
w[i,j]:=p;
end;
readln(s);
n:=length(s);
for i:= to n do
b[i]:=exc(s[i]);
flag:=false;
for i:= to do
if search(,n,i)= then
begin
write(a[i]);
flag:=true;
end;
if not flag then writeln('The name is wrong!') else writeln;
end.
bzoj1055的更多相关文章
- 【题解】 bzoj1055: [HAOI2008]玩具取名 (动态规划)
bzoj1055,懒得复制,戳我戳我 Solution: 区间动规(以后开始动规会在solution前面标注是啥动规 我觉的这道题挺难想了,但其实状态定义了一下子就出来了(还是不行啊) 我们定义状态\ ...
- 【BZOJ1055】[HAOI2008]玩具取名(动态规划)
[BZOJ1055][HAOI2008]玩具取名(动态规划) 题面 BZOJ 洛谷 题解 裸的区间\(dp\),设\(f[i][j][W/I/N/G]\)表示区间\([i,j]\)能否由某个字母替换过 ...
- 【bzoj1055】[HAOI2008]玩具取名
[bzoj1055][HAOI2008]玩具取名 2014年12月1日3,0111 Description 某人有一套玩具,并想法给玩具命名.首先他选择WING四个字母中的任意一个字母作为玩具的基本名 ...
- [bzoj1055][HAOI2008]玩具取名_区间dp
玩具取名 bzoj-1055 HAOI-2008 题目大意:给你一个用W,I,N,G组成的字符串,给你一些这四个字符之间的变换规则,每一个变换规则都是由一个字符变成两个字符,问这个字符串是否可能是由一 ...
- BZOJ1055: [HAOI2008]玩具取名[区间DP]
1055: [HAOI2008]玩具取名 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1588 Solved: 925[Submit][Statu ...
- BZOJ1055: [HAOI2008]玩具取名
... #include<bits/stdc++.h> using namespace std; int q[255]; char s[205]; char p[]={'W','I','N ...
- 【BZOJ-1055】玩具取名 区间DP
1055: [HAOI2008]玩具取名 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1560 Solved: 907[Submit][Statu ...
- bzoj千题计划199:bzoj1055: [HAOI2008]玩具取名
http://www.lydsy.com/JudgeOnline/problem.php?id=1055 区间DP dp[i][j][k] 表示区间[i,j]能否合成k #include<cst ...
- bzoj1055 ||P4290 [HAOI2008]玩具取名
目录 链接 思路 代码 链接 luogu bzoj 思路 区间dp 然后\(f[i][j][k]\) 区间\([i,j]\)能否变成\(k\)字符 (字符当然得转化一下) 字符的个数不多,直接暴力\( ...
随机推荐
- ionic(一) build你的第一个android apk
1.ionic start myApp tabs >>创建一个app 2.cd myApp >>进入myApp文件 3.ionic platform add andro ...
- 利用servlet技术实现验证码功能
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8" ...
- SomeThing of Memcache
Memcache for .net 文章一: http://blog.csdn.net/dinglang_2009/article/details/6917794 不定时更新
- ubuntu samba共享安装 配置
参考: http://www.360doc.com/content/11/0615/12/3989678_127081905.shtml 参考: http://xfshean.blog.163.com ...
- css按钮自适应
原理:利用a标签和i标签各自一个背景组合成为按钮,达到自适应. <!DOCTYPE html> <html> <head> <meta charset=&qu ...
- 简易的RestClient代码
package tests; import java.io.*; import org.apache.http.HttpEntity; import org.apache.http.HttpRespo ...
- scp命令使用
从 本地 复制到 远程 scp /home/daisy/full.tar.gz root@172.19.2.75:/home/root (然后会提示你输入另外那台172.19.2.75主机的root用 ...
- Python Tips and Traps(一)
1.如果想得到一个列表的index和内容,可以通过enumerate快速实现 drinks = ['coffee','tea', 'milk', 'water'] for index, drink i ...
- 工作流软件如何成为未来web的支柱
此文作者是 Kevin Lindquist,工作流平台Decisions的营销负责人,原文发表于VB上. Web 3.0 正在敲门,但是开门的人你永远都想不到:工作流软件. 传统上工作流软件是企业级的 ...
- 【转】ant命令总结
http://feiyeguohai.iteye.com/blog/1295922 ant命令总结 1 Ant是什么? Apache Ant 是一个基于 Java的生成工具. 生成工具在软件开发中用 ...