POJ 1185 炮兵阵地(经典的状态压缩DP)
题意:中文题。
思路,经典的状态压缩题目。
由于列长比较小,我们可以以行为阶段用状态压缩来做。
由于攻击只占两个格,这样从行的角度看,第i行的炮兵只与前i-1和前i-2行有关系。这样如果用j,k,l分别表示第i,i-1,i-2行的炮兵摆放状态,而num[i][j]表示第i个摆放状态为j时的炮兵个数。dp[i][k][j]表示以i为最后一行,倒数第一行摆放为j,倒数第二行摆放为k时的最优解。
这样得到状态转移方程dp[i][k][j]=max{dp[i-1][l][k]+num[i][j]},前提是j和k、l都不互相攻击。
其中炮兵的摆放状态要预处理出来,如果m至大为10,这样枚举的话最多是2^10。由于最后得到合法状态不多,使用的时候可以直接用保存的下标而不是用二进制表示状态。这样可以大大提高时空复杂度。
#include<cstdio>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<vector>
using namespace std;
vector<];
vector<];
][];
int m,n;
bool check(int sta,int d)
{
<<d);
}
bool check1(int c,int sta)//检查是否在山上放炮
{
; i<m; ++i)
if(grid[c][i]=='H'&&check(sta,i))
return false;
return true;
}
bool attack(int d,int sta)//某状态下判断同行之间是否相互攻击
{
>=&&check(sta,d-)) return true;
>=&&check(sta,d-)) return true;
<m&&check(sta,d+)) return true;
<m&&check(sta,d+)) return true;
return false;
}
int check2(int sta)//判断是否互相攻击和统计炮个数
{
;
; i<m; ++i)
if(check(sta,i))
{
;
else cnt++;
}
return cnt;
}
void init(int c)
{
; i<(<<m); ++i)
if(check1(c,i))//没有放在山坡上的情况
{
int cnt=check2(i);//判断是否互相攻击和炮个数
)
{
sta[c].push_back(i);//保存摆放位置状态
num[c].push_back(cnt);//保存对应状态下的个数
}
}
}
][][];
bool attack2(int sta1,int sta2)//判断不同行之间的状态下炮是否互相攻击
{
; i<m; ++i)
if(check(sta1,i)&&check(sta2,i)) return true;
return false;
}
int main()
{
scanf("%d%d",&n,&m);
; i<=n; ++i)
{
scanf("%s",grid[i]);
init(i);
}
)
{
;
;i<sta[].size();++i)
ans=max(ans,num[][i]);
printf("%d\n",ans);
;
}
; i<sta[].size(); ++i)
; j<sta[].size(); ++j)
][i],sta[][j]))
dp[][i][j]=num[][i]+num[][j];
; i<=n; ++i)
{
; k<sta[i].size(); ++k)
; j<sta[i-].size(); ++j)
{
][j];
if(!attack2(stak,staj))
{
;
; l<sta[i-].size(); ++l)
{
][l];
if(!attack2(stak,stal)&&!attack2(staj,stal))
maxn=max(maxn,dp[i-][l][j]);
}
dp[i][j][k]=maxn+num[i][k];
}
}
}
;
; i<sta[n].size(); ++i)
; j<sta[n-].size(); ++j)
ans=max(ans,dp[n][j][i]);
printf("%d\n",ans);
;
}
POJ 1185 炮兵阵地(经典的状态压缩DP)的更多相关文章
- POJ 1185 炮兵阵地 经典的 状态压缩dp
炮兵阵地 Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 16619 Accepted: 6325 Description ...
- POJ 1185 炮兵阵地(动态规划+状态压缩)
炮兵阵地 Description 司令部的将军们打算在N*M的网格地图上部署他们的炮兵部队.一个N*M的地图由N行M列组成,地图的每一格可能是山地(用"H" 表示),也可能是平原( ...
- poj 1185 炮兵阵地 [经典状态压缩DP]
题意:略. 思路:由于每个大炮射程为2,所以如果对每一行状态压缩的话,能对它造成影响的就是上面的两行. 这里用dp[row][state1][state2]表示第row行状态为state2,第row- ...
- poj -1185 炮兵阵地 (经典状压dp)
http://poj.org/problem?id=1185 参考博客:http://poj.org/problem?id=1185 大神博客已经讲的很清楚了,注意存状态的时候是从1开始的,所以初始化 ...
- POJ 1185 炮兵阵地 状压dp
题目链接: http://poj.org/problem?id=1185 炮兵阵地 Time Limit: 2000MS Memory Limit: 65536K 问题描述 司令部的将军们打算在N*M ...
- POJ 1185 炮兵阵地(状压DP)
炮兵阵地 Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 26426 Accepted: 10185 Descriptio ...
- poj - 1185 炮兵阵地 状压DP 解题报告
炮兵阵地 Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 21553 Accepted: 8363 Description ...
- POJ 1185炮兵阵地 (状压DP)
题目链接 POJ 1185 今天艾教留了一大堆线段树,表示做不动了,就补补前面的题.QAQ 这个题,我第一次写还是像前面HDU 2167那样写,发现这次影响第 i 行的还用i-2行那样,那以前的方法就 ...
- POJ - 1185 炮兵阵地 (插头dp)
题目链接 明明是道状压dp的题我为啥非要用插头dp乱搞啊 逐行枚举,设dp[i][S]为枚举到第i个格子时,状态为S的情况.S为当前行上的“插头”状态,每两个二进制位表示一个格子,设当前格子为(x,y ...
随机推荐
- Java调用Oracle存储过程过程中几个问题
1.java.sql.SQLException: 无效的名称模式: STKSETTLEADMIN.TY_MARKETDATA 用户STKSETTLEADMIN下没有TY_MARKETDATA,类型TY ...
- C# 给软件加注册码功能
为自己写的程序加一个注册功能吧.生成的机器号是根据CPU和硬盘号来的,根据自己的需求改成是否是随机生成. 代码直接粘贴到新建类覆盖原代码就能直接用了. using System; using Syst ...
- python 练习 19
#!/usr/bin/python # -*- coding: UTF-8 -*- for n in range(100,1000): i = n / 100 j = n / 10 % 10 k = ...
- robotframework笔记4
机器人框架概述 机器人框架是一个通用的开源的自动化测试框架 验收测试和验收测试驱动开发(ATDD).它具有易于使用的表格的测试数据 语法采用关键字驱动 测试方法.其检测能力可以通过测试库 用Pyt ...
- each用法
1.数组用法 <script> var s=["s","i","l","e","n",& ...
- Firefox火狐Flash插件卡死问题完美解决方法(转载)
http://www.ihacksoft.com/firefox-flash-protectedmode.html 其实这个问题以前就出现过,而最近该问题又出现在最新的 Windows 8.1 系统中 ...
- XPath 语法示例
参考:http://www.w3school.com.cn/xpath/xpath_syntax.asp XPath 使用路径表达式来选取 XML 文档中的节点或节点集.节点是通过沿着路径 (path ...
- Vim经典讲解
http://blog.csdn.net/niushuai666/article/details/7275406
- Windows Store App 应用设置存储
应用设置存储主要分为本地存储和漫游存储两种方式.本地存储是指将应用的设置信息存储在本地存储空间中,而漫游存储则是指将应用的设置信息存储在网络服务器中,相对于本地存储而言,漫游存储支持多台设备之间的应用 ...
- JDE函数--获取当前登录人的描述
业务描述:当前登录人ID为数字,中文姓名保存在描述1字段中 方式: 根据系统变量获取用户的地址号,根据TableIO获取用户描述1.如下图所示: 由于使用AN8时,变量类型不一致,所以使用函数将cha ...