http://poj.org/problem?id=1185

一次考虑两行,比一行略为复杂。sta保存每种状态炮兵位置,sum保存每种状态当行炮兵总数,a保存地形,dp[i][j][k]表示到第i行当前行j状态上一行k状态的最大炮兵数。

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
//int main()
//{
// int num = 0;
// for(int i = 0;i <= (1<<10);i++)
// {
// if(i & (i<<2) || i & (i<<1)) continue;
// num++;
// }
// printf("%d",num);
//} int dp[][][],a[] = {},n,m,sta[],sum[] = {}; int main()
{
memset(dp,-,sizeof(dp));
scanf("%d%d",&n,&m);
getchar();
if(n == && m == )
{
printf("0\n");
return ;
}
for(int i = ;i < n;i++)
{
char temp[];
gets(temp);
for(int j = ;j < m;j++)
{
if(temp[j] == 'H') a[i] |= (<<j);
}
}
// for(int i = 0;i < n;i++) printf("%d\n",a[i]);
int cnt = ;
for(int i = ;i < (<<m);i++)
{
if(i & (i<<)) continue;
if(i & (i<<)) continue;
sta[cnt] = i;
int temp = i;
while(temp)
{
sum[cnt] += temp%;
temp /= ;
}
cnt++;
}
// for(int i = 0;i < cnt;i++) printf("%d %d\n",sta[i],sum[i]);
for(int i = ;i < cnt;i++)
{
if(a[] & sta[i]) continue;
dp[][i][] = sum[i];
}
// for(int i = 0;i < cnt;i++) printf("%d\n",dp[0][i][0]);
for(int i = ;i < cnt;i++)
{
if(a[] & sta[i]) continue;
for(int j = ;j < cnt;j++)
{
if(sta[i] & sta[j]) continue;
dp[][i][j] = max(dp[][i][j],dp[][j][]+sum[i]);
}
}
for(int i = ;i < n;i++)
{
for(int j = ;j < cnt;j++)
{
if(a[i] & sta[j]) continue;
for(int k = ;k < cnt;k++)
{
if(sta[j] & sta[k]) continue;
for(int l = ;l < cnt;l++)
{
if(sta[j] & sta[l]) continue;
if(dp[i-][k][l] == -) continue;
dp[i][j][k] = max(dp[i][j][k],dp[i-][k][l]+sum[j]);
}
}
}
}
// for(int i = 0;i < cnt;i++)
// {
// for(int j = 0;j < cnt;j++) printf("%d ",dp[n-1][i][j]);
// printf("\n");
// }
int ans = -;
for(int i = ;i < cnt;i++)
{
for(int j = ;j < cnt;j++) ans = max(ans,dp[n-][i][j]);
}
printf("%d\n",ans);
return ;
}

POJ_1185_状态压缩dp的更多相关文章

  1. hoj2662 状态压缩dp

    Pieces Assignment My Tags   (Edit)   Source : zhouguyue   Time limit : 1 sec   Memory limit : 64 M S ...

  2. POJ 3254 Corn Fields(状态压缩DP)

    Corn Fields Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 4739   Accepted: 2506 Descr ...

  3. [知识点]状态压缩DP

    // 此博文为迁移而来,写于2015年7月15日,不代表本人现在的观点与看法.原始地址:http://blog.sina.com.cn/s/blog_6022c4720102w6jf.html 1.前 ...

  4. HDU-4529 郑厂长系列故事——N骑士问题 状态压缩DP

    题意:给定一个合法的八皇后棋盘,现在给定1-10个骑士,问这些骑士不能够相互攻击的拜访方式有多少种. 分析:一开始想着搜索写,发现该题和八皇后不同,八皇后每一行只能够摆放一个棋子,因此搜索收敛的很快, ...

  5. DP大作战—状态压缩dp

    题目描述 阿姆斯特朗回旋加速式阿姆斯特朗炮是一种非常厉害的武器,这种武器可以毁灭自身同行同列两个单位范围内的所有其他单位(其实就是十字型),听起来比红警里面的法国巨炮可是厉害多了.现在,零崎要在地图上 ...

  6. 状态压缩dp问题

    问题:Ignatius has just come back school from the 30th ACM/ICPC. Now he has a lot of homework to do. Ev ...

  7. BZOJ-1226 学校食堂Dining 状态压缩DP

    1226: [SDOI2009]学校食堂Dining Time Limit: 10 Sec Memory Limit: 259 MB Submit: 588 Solved: 360 [Submit][ ...

  8. Marriage Ceremonies(状态压缩dp)

     Marriage Ceremonies Time Limit:2000MS     Memory Limit:32768KB     64bit IO Format:%lld & %llu ...

  9. HDU 1074 (状态压缩DP)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1074 题目大意:有N个作业(N<=15),每个作业需耗时,有一个截止期限.超期多少天就要扣多少 ...

随机推荐

  1. MapGIS注记文字无损转入ArcGIS软件

    在GIS软件中,注释是一种十分特殊的对象,虽然各类软件都支持注释,但它却不属于GIS的基本对象.因此通常的格式转换软件,都不对注释对象做特别的支持,我们最常见的Shape文件格式就只有点.线.面要素, ...

  2. js的内存泄漏场景、监控以及分析

    内存泄漏 Q:什么是内存泄漏? 字面上的意思,申请的内存没有及时回收掉,被泄漏了 Q:为什么会发生内存泄漏? 虽然前端有垃圾回收机制,但当某块无用的内存,却无法被垃圾回收机制认为是垃圾时,也就发生内存 ...

  3. Eureka 主动下线服务

    原因: 测试环境由于机器换ip,神奇的出现了更新之前,之后的IP同时在Eureka上注册了. 方法一:直接停掉服务 默认情况下,如果Eureka Server在90秒没有收到Eureka客户的续约,它 ...

  4. cf - 920 c 求能否实现交换

    C. Swap Adjacent Elements time limit per test 1 second memory limit per test 256 megabytes input sta ...

  5. Android栈溢出漏洞利用练习

    在Github上看到一个Linux系统上的栈溢出漏洞利用练习项目: easy-linux-pwn.在原项目基础上,我稍微做了一些改动,将这个项目移植到了Android 9.0系统上: easy-and ...

  6. @RequestParam,@PathVariable,@RequestBody

    @RequestParam 和 @PathVariable 注解是用于从request中接收请求的,两个都可以接收参数,关键点不同的是@RequestParam 是从request里面拿取值,而 @P ...

  7. 如何高效实用 Git

    Git 工作流 只要项目是多人参与的,那么就需要使用正确的 Git 工作流程. 下面介绍一个简单有效的工作流程. 场景 假设有一个项目,要开发下一代的 Facebook,你就是这个项目的技术 lead ...

  8. .net Core发布至IIS完全手册带各种踩坑

    服务器环境配置 和各位大爷报告一下我的服务器环境 : Windows Server 2012 iis 8 小插曲开始: 运维大哥在昨天给了我一台新的server 0环境开始搭建 . 并且没有安装任何的 ...

  9. HUAWEI MateBook Fn 功能键/热键切换、设置方法

    原文地址:https://club.huawei.com/thread-13130964-1-1.html HUAWE MateBook E/X/D的F1.F2 等键默认是热键优先.在热键模式下,要想 ...

  10. 源码的说明 ASP.NET MVC 5框架揭秘.zip

    第1章 S101 MVP(SC)模式中Presenter与View之间的交互 S102 迷你版的ASP.NET MVC框架 第2章 S201 通过路由实现请求地址与.aspx页面的映射 S202 基本 ...