hdu 4539(状态压缩dp)
题意:曼哈顿距离是指:|x1-x2|+|y1-y2|,只要知道这个概念题意就懂了。
分析:这道题与前面做的几道题有所不同,因为当前行不仅与前一行有关,而且与前两行有关,所以我们开数组的时候还要记录前两行的状态,所以我们需要开设三维数组。
代码实现:
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std; int n,m,a[];
int dp[][][],st[],num,b[]; int suan(int x)
{
int sum=,i;
for(i=; i<=; i++)
{
if((x&))
sum++;
x=x>>;
}
return sum;
} void chushihua()
{
int i,max=<<;
for(i=; i<max; i++)
if((i&(i<<))==&&(i&(i>>))==)
{
st[num]=i;
b[num++]=suan(i);
}
} void solve()
{
int i,j,k,l,p=,max=<<m,res=,temp;
memset(dp,,sizeof(dp));
if(n>=)
for(i=; i<num&&st[i]<max; i++)
{
if((a[]&st[i])!=st[i])
continue;
temp=b[i];
dp[][][i]=temp;
}
if(n>)
{
p=p^;
for(i=; i<num&&st[i]<max; i++)
{
if((a[]&st[i])!=st[i])
continue;
temp=b[i];
for(j=; j<num&&st[j]<max; j++)
{
if((a[]&st[j])!=st[j])
continue;
if((st[i]&(st[j]<<))!=||(st[i]&(st[j]>>))!=)
continue;
if(dp[][j][i]<dp[][][j]+temp)
dp[][j][i]=dp[][][j]+temp;
}
}
for(i=; i<=n; i++)
{
p=p^;
for(j=; j<num&&st[j]<max; j++)
{
if((a[i]&st[j])!=st[j])
continue;
temp=b[j];
for(k=; k<num&&st[k]<max; k++)
{
if((st[j]&(st[k]<<))!=||(st[j]&(st[k]>>))!=)
continue;
if((a[i-]&st[k])!=st[k])
continue;
for(l=; l<num&&st[l]<max; l++)
{
if((a[i-]&st[l])!=st[l])
continue;
if((st[k]&(st[l]<<))!=||(st[k]&(st[l]>>))!=)
continue;
if((st[l]&st[j])!=)
continue;
if(dp[p][k][j]<dp[-p][l][k]+temp)
dp[p][k][j]=dp[-p][l][k]+temp;
}
}
}
}
}
for(i=; i<num&&st[i]<max; i++)
for(j=; j<num&&st[j]<max; j++)
{
temp=dp[p][i][j];
if(temp>res)
res=temp;
}
printf("%d\n",res);
} int main()
{
int i,j,temp;
num=;
memset(b,,sizeof(b));
chushihua();
while(scanf("%d%d",&n,&m)!=EOF)
{
memset(a,,sizeof(a));
for(i=; i<=n; i++)
{
a[i]=;
for(j=; j<=m; j++)
{
scanf("%d",&temp);
a[i]=(a[i]<<)+temp;
}
}
solve();
}
return ;
}
hdu 4539(状态压缩dp)的更多相关文章
- HDU 1074 (状态压缩DP)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1074 题目大意:有N个作业(N<=15),每个作业需耗时,有一个截止期限.超期多少天就要扣多少 ...
- HDU 3341 状态压缩DP+AC自动机
题目大意: 调整基因的顺序,希望使得最后得到的基因包含有最多的匹配串基因,使得所能达到的智商最高 这里很明显要用状态压缩当前AC自动机上点使用了基因的情况所能达到的最优状态 我最开始对于状态的保存是, ...
- hdu 4284 状态压缩dp
题意: 有N 个点的无向图,要去其中 h个地点做事,做事需要先办理护照,之后可以挣一定数量的钱,知道了一开始有的总钱数,和 一些城市之间 道路的花费,问可不可以在 指定的 h 个城 ...
- hdu 2167 状态压缩dp
/* 状态转移方程:dp[i][j]=Max(dp[i][j],dp[i-1][k]+sum[i][j]); */ #include<stdio.h> #include<string ...
- HDU 4856 (状态压缩DP+TSP)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4856 题目大意:有一个迷宫.迷宫里有些隧道,每个隧道有起点和终点,在隧道里不耗时.出隧道就耗时,你的 ...
- HDU 4640 状态压缩DP 未写完
原题链接:http://acm.hdu.edu.cn/showproblem.php?pid=4640 解题思路: 首先用一个简单的2^n*n的dp可以求出一个人访问一个给定状态的最小花费,因为这i个 ...
- 2016"百度之星" - 初赛(Astar Round2A)1002 / HDU 5691 状态压缩DP
Sitting in Line Problem Description 度度熊是他同时代中最伟大的数学家,一切数字都要听命于他.现在,又到了度度熊和他的数字仆人们玩排排坐游戏的时候了.游戏的规则十 ...
- HDU 5067 (状态压缩DP+TSP)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5067 题目大意:蓝翔挖掘机挖石子.把地图上所有石子都运回起点,问最少耗时. 解题思路: 首先得YY出 ...
- hdu 1074(状态压缩dp+记录路径)
题意:给了n个家庭作业,然后给了每个家庭作业的完成期限和花费的实践,如果完成时间超过了期限,那么就要扣除分数,然后让你找出一个最优方案使扣除的分数最少,当存在多种方案时,输出字典序最小的那种,因为题意 ...
随机推荐
- mysql+heartbeat+DRBD+LVS集群
- MCU晶体旁边电容的作用及振荡电路的分析
绝大多数的MCU爱好者对MCU晶体两边要接一个22pF附近的电容不理解,因为这个电容有些时候是可以不要的.参考很多书籍,讲解的很少,往往提到最多的是起稳定作用,负载电容之类的话,都不是很深入理论的分析 ...
- android中使用html作布局文件
在android开发中,通常使用xml格式来描述布局文件.就目前而言,熟悉android布局及美化的人员少之又少,出现了严重的断层.大部分企业,其实还是程序员自己动手布局.这样既浪费时间和精力,也未必 ...
- Winsock IOCP模型(四篇)
http://blog.csdn.net/visualeleven/article/details/6041893 http://blog.csdn.net/visualeleven/article/ ...
- wrong number of arguments,java方法反射时数组参数的坑
java方法中只有一个参数是数组,反射的时候我们不能想当然的传歌数组进去,传数组进去的时候表示多个参数. 两个数组不是一个意思啊. 我们应该把数组转为objet,这样才表示一个参数. import j ...
- iphone/ipad实现自定义的开关UISwitch(continuous,clipsToBounds,userInteractionEnabled属性)
这里主要讲几个UIView的几个属性,具体大家可以下载代码看看, 下载地址是: http://download.csdn.net/detail/rhljiayou/5960003 实现效果是: 代码中 ...
- linux中/etc/init.d [转]
一.关于/etc/init.d 如果你使用过linux系统,那么你一定听说过init.d目录.这个目录到底是干嘛的呢?它归根结底只做了一件事情,但这件事情非同小可,是为整个系统做的,因此它非常重要.i ...
- linux系统的权限介绍
让我们用t o u c h命令创建一个文件:$ touch myfile现在对该目录使用ls -l命令: 我们已经创建了一个空文件,正如我们所希望的那样,第一个横杠告诉我们该文件是一个普通文件.你将会 ...
- iTunes获取下载的安装包
打开iTunes, 偏好设置,选择高级,即可找到文件路径
- STL笔记(1)map
STL笔记(1)map STL之map ZZ from http://hi.baidu.com/liyanyang/blog/item/d5c87e1eb3ba06f41bd576cf.html 1. ...