1187: [HNOI2007]神奇游乐园 - BZOJ
Description
经历了一段艰辛的旅程后,主人公小P乘坐飞艇返回。在返回的途中,小P发现在漫无边际的沙漠中,有一块狭长的绿地特别显眼。往下仔细一看,才发现这是一个游乐场,专为旅途中疲惫的人设计。娱乐场可以看成是一块大小为n×m的区域,且这个n×m的区域被分成n×m个小格子,每个小格子中就有一个娱乐项目。然而,小P并不喜欢其中的所有娱乐项目,于是,他给每个项目一个满意度。满意度为正时表示小P喜欢这个项目,值越大表示越喜欢。为负时表示他不喜欢,这个负数的绝对值越大表示他越不喜欢。为0时表示他对这个项目没有喜恶。小P决定将飞艇停在某个小格中,然后每步他可以移动到相邻的上下左右四个格子的某个格子中。小P希望找一条路径,从飞艇所在格出发,最后又回到这个格子。小P有一个习惯,从不喜欢浪费时间。因此,他希望经过每个格子都是有意义的:他到一个地方后,就一定要感受以下那里的惊险和刺激,不管自己是不是喜欢那里的娱乐项目。而且,除了飞艇所在格,其他的格子他不愿意经过两次。小P希望自己至少要经过四个格子。 在满足这些条件的情况下,小P希望自己玩过的娱乐项目的满意度之和最高。你能帮他找到这个最高的满意度之和吗?
Input
输入文件中的第一行为两个正整数n和m,表示游乐场的大小为n×m。因为这个娱乐场很狭窄,所以n和m满足:2<=n<=100,2<=m<=6。 接下来的n行,每行有m个整数,第i行第j列表示游乐场的第i行第j列的小格子中的娱乐项目的满意度,这个满意度的范围是[-1000,1000]。同一行的两个整数之间用空格隔开。
Output
输出文件中仅一行为一个整数,表示最高的满意度之和。
Sample Input
4 4
100 300 -400 400
-100 1000 1000 1000
-100 -100 -100 -100
-100 -100 -100 1000
Sample Output
4000
HINT
大家测下这个数据
5 5
1 1 -100 3 3
1 1 -100 3 3
1 1 -100 3 3
1 1 -100 3 3
1 1 -100 3 3
结果是30?
第二道插头DP,插头DP还是陈丹琦说得好
多看论文有助于各方面知识的提高,看吧
做了两道,感想就是空间一定要开足,你要算出你用多少,我开少了就WA了
每一种情况要搞清楚最好是自己画一下图,讨论一下,在提交之前先自己随机几个大数据,确认没有什么明显的错误再交
var
a:array[..,..]of longint;
f:array[..,..,..]of longint;
flag:array[..]of boolean;
g:array[..,..]of longint;
s,z:array[..]of longint;
n,m,ans:longint; function pd(k:longint):boolean;
var
i,j,save:longint;
begin
j:=;
save:=k;
for i:= to m+ do
begin
s[i]:=k and ;
if s[i]= then exit(false);
if (j>)and(s[z[j]]=)and(s[i]=) then
begin
g[save,z[j]]:=i;
g[save,i]:=z[j];
dec(j);
end
else
if (s[i]=)or(s[i]=) then
begin
inc(j);
z[j]:=i;
end;
k:=k>>;
end;
if j= then exit(true);
exit(false);
end; function max(x,y:longint):longint;
begin
if x>y then exit(x);
exit(y);
end; procedure init;
var
i,j:longint;
begin
read(n,m);
for i:= to n do
for j:= to m do
read(a[i,j]);
fillchar(f,sizeof(f),<<);
f[,m,]:=;
ans:=-maxlongint;
end; procedure work;
var
i,j,k:longint;
begin
for k:= to <<(m<<+)- do
flag[k]:=pd(k);
for i:= to n do
for j:= to m do
if j= then
begin
for k:= to <<(m<<)- do
if flag[k] then
begin
if k and = then
begin
f[i,j,k<<]:=max(f[i-,m,k],f[i,j,k<<]);
f[i,j,k<<+]:=max(f[i-,m,k]+a[i,j],f[i,j,k<<+]);
end
else
if k and = then
begin
f[i,j,k<<]:=max(f[i-,m,k]+a[i,j],f[i,j,k<<]);
f[i,j,k<<-]:=max(f[i-,m,k]+a[i,j],f[i,j,k<<-]);
end;
end;
end
else
begin
for k:= to <<(m<<+)- do
if flag[k] then
begin
if k and(<<(j<<-))= then
begin
if k and(<<(j<<))= then
begin
f[i,j,k+<<(j<<-)]:=max(f[i,j-,k]+a[i,j],f[i,j,k+<<(j<<-)]);
f[i,j,k]:=max(f[i,j,k],f[i,j-,k]);
end
else
if k and(<<(j<<))=<<(j<<) then
begin
f[i,j,k]:=max(f[i,j-,k]+a[i,j],f[i,j,k]);
f[i,j,k-<<(j<<-)]:=max(f[i,j-,k]+a[i,j],f[i,j,k-<<(j<<-)]);
end
else
if k and(<<(j<<))=<<(j<<) then
begin
f[i,j,k]:=max(f[i,j-,k]+a[i,j],f[i,j,k]);
f[i,j,k-<<(j<<-)]:=max(f[i,j-,k]+a[i,j],f[i,j,k-<<(j<<-)]);
end;
end
else
if k and(<<(j<<-))=<<(j<<-) then
begin
if k and(<<(j<<))= then
begin
f[i,j,k]:=max(f[i,j-,k]+a[i,j],f[i,j,k]);
f[i,j,k+<<(j<<-)]:=max(f[i,j-,k]+a[i,j],f[i,j,k]);
end
else
if k and(<<(j<<))=<<(j<<) then f[i,j,k-<<(g[k,j+]<<-)-<<(j<<-)]:=max(f[i,j-,k]+a[i,j],f[i,j,k-<<(g[k,j+]<<-)-<<(j<<-)])
else
if k and(<<(j<<))=<<(j<<) then if k=<<(j<<-) then ans:=max(f[i,j-,k]+a[i,j],ans);
end
else
if k and(<<(j<<-))=<<(j<<-) then
begin
if k and(<<(j<<))= then
begin
f[i,j,k]:=max(f[i,j-,k]+a[i,j],f[i,j,k]);
f[i,j,k+<<(j<<-)]:=max(f[i,j-,k]+a[i,j],f[i,j,k+<<(j<<-)]);
end
else
if k and(<<(j<<))=<<(j<<) then f[i,j,k-<<(j<<-)]:=max(f[i,j-,k]+a[i,j],f[i,j,k-<<(j<<-)])
else
if k and(<<(j<<))=<<(j<<) then f[i,j,k+<<(g[k,j]<<-)-<<(j<<-)]:=max(f[i,j-,k]+a[i,j],f[i,j,k+<<(g[k,j]<<-)-<<(j<<-)]);
end;
end;
end;
write(ans);
end; begin
init;
work;
end.
1187: [HNOI2007]神奇游乐园 - BZOJ的更多相关文章
- bzoj 1187: [HNOI2007]神奇游乐园 插头dp
1187: [HNOI2007]神奇游乐园 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 668 Solved: 337[Submit][Statu ...
- 【BZOJ】1187: [HNOI2007]神奇游乐园
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1187 每个格子都具有权值,求任意一个回路使得路径上的权值和最大. 裸的插头DP,注意一下几 ...
- bzoj:1187: [HNOI2007]神奇游乐园
Description 经历了一段艰辛的旅程后,主人公小P乘坐飞艇返回.在返回的途中,小P发现在漫无边际的沙漠中,有一块狭长的绿地特别显眼.往下仔细一看,才发现这是一个游乐场,专为旅途中疲惫的人设计. ...
- bzoj 1187: [HNOI2007]神奇游乐园【插头dp】
要判边界!!要判边界!!要判边界!!if(j!=m)!!! 我真是zz横着转移要判断到底能不能向右边出边-- 然后剩下的和1814差不多,九十因为不要求经过所有格子,所以左右括号随时可以合并,但是注意 ...
- 【BZOJ1187】[HNOI2007]神奇游乐园 插头DP
[BZOJ1187][HNOI2007]神奇游乐园 Description 经历了一段艰辛的旅程后,主人公小P乘坐飞艇返回.在返回的途中,小P发现在漫无边际的沙漠中,有一块狭长的绿地特别显眼.往下仔细 ...
- 洛谷 P3190 [HNOI2007]神奇游乐园 解题报告
P3190 [HNOI2007]神奇游乐园 Description 给你一个 \(m * n\) 的矩阵,每个矩阵内有个权值\(V(i,j)\) (可能为负数),要求找一条回路,使得每个点最多经过一次 ...
- [bzoj1187][HNOI2007]神奇游乐园_插头dp
bzoj-1187 HNOI-2007 神奇游乐园 题目大意:经历了一段艰辛的旅程后,主人公小P乘坐飞艇返回.在返回的途中,小P发现在漫无边际的沙漠中,有一块狭长的绿地特别显眼.往下仔细一看,才发现这 ...
- 【bzoj1187】 HNOI2007—神奇游乐园
http://www.lydsy.com/JudgeOnline/problem.php?id=1187 (题目链接) 题意 一个$n*m$的矩阵,其中每一个位置有一个权值,求一条回路使得经过的位置的 ...
- BZOJ1187:[HNOI2007]神奇游乐园——题解
http://www.lydsy.com/JudgeOnline/problem.php?id=1187 Description 经历了一段艰辛的旅程后,主人公小P乘坐飞艇返回.在返回的途中,小P发现 ...
随机推荐
- asp.net中C#对象与方法 属性详解
C#对象与方法 一.相关概念: 1.对象:现实世界中的实体 2. 类:具有相似属性和方法的对象的集合 3.面向对象程序设计的特点:封装 继承 多态 二.类的定义与语法 1.定义类: 修饰符 类名称 ...
- COM 参数有in, out ,retval
COM 参数有in, out ,retval 来源:http://blog.sina.com.cn/s/blog_472a9f0c01017uer.html In 输入参数,它的值不被返回 Ou ...
- 逻辑推理:在一个100条语句的列表中,第n条语句是“在这个列表中,恰有n条语句为假”,可以得出什么结论?
<离散数学及其应用>第六版1.1练习题第43题的个人分析 题目:在一个100条语句的列表中,第n条语句是"在这个列表中,恰有n条语句为假".......... ...
- (转)重磅出击:MongoDB 3.0正式版即将发布
MongoDB 今天宣布 3.0 正式版本即将发布.这标志着 MongoDB 数据库进入了一个全新的发展阶段,提供强大.灵活而且易于管理的数据库管理系统. MongoDB 3.0 在性能和伸缩性方面都 ...
- 老老实实学WCF[第一篇] Hell wcf
老老实实学WCF 第一篇 Hello WCF WCF(Windows Communication Foundation)是微软公司推出的面向服务技术的集大成者,涵盖继承了其之前发布的所有的分布式应用 ...
- 抓取dump
1,在程序奔溃前部署.adplus.exe -crash -pn explorer.exe -o d: -crash:当进程挂掉的时候抓取dump,只能抓取到进程报错时的信息,如果进程不报错,就无法抓 ...
- input中id和name属性的区别。
input中id和name属性的区别. 做网站很久了,但到现在还没有搞明白input中name和id的区别,最近学习jquery,又遇到这个问题,就在网上搜集资料.看到这篇,就整理出来,以备后用. 可 ...
- JQuery 预热
这是第一次在博客园写随笔,之所以有这样的冲动是因为每次看到很多园友不断的发表文章,记录下自己的点点滴滴,内心就在不断的忏悔,我很敬佩这种人,不管他们表达的东西是初级还是精辟,我认为只要去坚持写了就是一 ...
- 获取客户端访问的ip地址
function real_ip() { static $realip = NULL; if ($realip !== NULL) { return $realip; } if (isset($_SE ...
- DTCMS会员中心快速更改样式思路
非常简便 制作一个public.css文件,包含网站头部和底部的样式代码 每个会员中心模版导入这个文件就可以 把原先style.css的头部和底部样式代码删除