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 ...
随机推荐
- 修复 SQLite 数据库文件
目 录 第1章 说明 1 1 下载SQLite Tools 1 2 运行 2 第1章 说明 笔者编写的一个程序,无法往 SQLite 数据库文件里写数据.使用SQLiteSpy打开该 ...
- jquery 学习
地址:http://www.w3school.com.cn/jquery/jquery_dom_add.asp
- 向html中添加节点
简单: ①,js中: (function () { var box=document.querySelector("#box"); var con1=document.create ...
- var isObj = length === undefined || i
这个其实是因为你前面那个===是肯定为false导致的,所以执行到了i那一步了var length=undefined;var a=length===undefined || i;这样你不定义i也是不 ...
- js正则标志/g /i /m的用法,以及实例
js正则标志/g /i /m的用法,以及实例 正则的思想都是一样的,但是具体的写法会有所不同,在这里提到的/g,/i,/m在其他的地方也许就不能用了. 一,js正则标志/g,/i,/m说明 1,/ ...
- hdu 3038 How Many Answers Are Wrong ( 带 权 并 查 集 )
How Many Answers Are Wrong Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Ja ...
- HDUOJ-------2493Timer(数学 2008北京现场赛H题)
Timer Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Subm ...
- bug数量问题研究
最近感觉很扯蛋的事情就是测试人员提bug的问题.先说下前提,公司测试会以提bug数量来做为一部分员工绩效的成份.再说一下公司从需求到开发 到测试,先是需求出一个文档,开发根据文档做功能的开发,然后测试 ...
- Notepad++ 配置java编译环境
仅限于学习java或小的java程序使用.正常写代码还是eclipse吧 ---------------------分割线----------------------------- 1.配置JDK环境 ...
- C#入门篇6-11:字符串操作 查找与替换
#region 查找与替换 public class C4 { //查找 public static void StrFind() { //目标字符串 string str1 = "~awe ...