POJ1185 [NOI2001] 炮兵阵地 (状压DP)
又是一道有合法性检测的状压题。
dp[i][j][k]表示第i行状态为j,i-1行状态为k时前i行放置的最大数量。
注意22行统计二进制数中1的个数时的巧妙方法。
1 #include<cstdio>
2 #include<cstring>
3 #include<algorithm>
4 using namespace std;
5 int N,M;
6 char map[110][20],num[70],top;
7 int stk[70],cur[70];
8 int dp[110][70][70];
9
10 bool check(int x){//判断该状态是否合法,横向检测相邻的1之间的距离不能小于3
11 if(x&(x<<1)) return 0;
12 if(x&(x<<2)) return 0;
13 return 1;
14 }
15
16 void init(){//记录所有可能的合法状态,最多60种
17 top=0;
18 for(int i=0;i<(1<<M);i++)
19 if(check(i)) stk[top++]=i;
20 }
21
22 int count(int x){//统计状态x的二进制中1的个数
23 int cnt=0;
24 while(x){
25 cnt++;
26 x&=(x-1);//很巧妙的求解方法
27 }
28 return cnt;
29 }
30
31 bool fit(int x,int k){
32 if(cur[k]&x) return 0;
33 return 1;
34 }
35
36 int solve(){
37 int ans=0;
38 memset(dp,-1,sizeof(dp));
39 for(int j=0;j<top;j++){//初始化第一行状态
40 num[j]=count(stk[j]);//统计每个合法状态中1的个数
41 if(fit(stk[j],1)){
42 dp[1][j][0]=num[j];//第一行状态为j,上一行状态为第0个状态,即000000
43 ans=max(ans,dp[1][j][0]);
44 }
45 }
46 for(int i=2;i<=N;i++)
47 for(int j=0;j<top;j++){
48 if(!fit(stk[j],i)) continue;
49 for(int k=0;k<top;k++){
50 if(stk[j]&stk[k]) continue;
51 for(int t=0;t<top;t++){
52 if(stk[j]&stk[t]) continue;
53 if(dp[i-1][k][t]==-1) continue;
54 dp[i][j][k]=max(dp[i][j][k],dp[i-1][k][t]+num[j]);
55 }
56 if(i==N) ans=max(ans,dp[i][j][k]);
57 }
58 }
59 return ans;
60 }
61
62 int main(){
63 while(~scanf("%d%d",&N,&M)){
64 init();
65 for(int i=1;i<=N;i++)
66 scanf("%s",map[i]+1);
67 for(int i=1;i<=N;i++){
68 cur[i]=0;
69 for(int j=1;j<=M;j++)
70 if(map[i][j]=='H')
71 cur[i]+=(1<<(j-1));
72 }
73 printf("%d\n",solve());
74 }
75 return 0;
76 }
POJ1185 [NOI2001] 炮兵阵地 (状压DP)的更多相关文章
- [POJ1185][NOI2001]炮兵阵地 状压DP
题目链接:http://poj.org/problem?id=1185 很裸的状压,考虑对于一行用二进制储存每一种的状态,但是状态太多了做不了. 观察到有很多状态都是不合法的,于是我们预处理出合法的状 ...
- 洛谷P2704 [NOI2001]炮兵阵地 [状压DP]
题目传送门 炮兵阵地 题目描述 司令部的将军们打算在N*M的网格地图上部署他们的炮兵部队.一个N*M的地图由N行M列组成,地图的每一格可能是山地(用“H” 表示),也可能是平原(用“P”表示),如下图 ...
- P2704 [NOI2001]炮兵阵地 (状压DP)
题目: P2704 [NOI2001]炮兵阵地 解析: 和互不侵犯一样 就是多了一格 用\(f[i][j][k]\)表示第i行,上一行状态为\(j\),上上行状态为\(k\)的最多的可以放的炮兵 发现 ...
- [NOI2001]炮兵阵地 状压DP
题面: 司令部的将军们打算在N*M的网格地图上部署他们的炮兵部队.一个N*M的地图由N行M列组成,地图的每一格可能是山地(用“H” 表示),也可能是平原(用“P”表示),如下图.在每一格平原地形上最多 ...
- 【POJ1185】炮兵阵地 状压DP
感觉总是被一些SB错误所困扰... 差不多还是(模板题)注意数组空间的大小,和对于合法状态的判断. f[i][j][k]=max(f[i][k][j],f[i-1][l][k]+num[j]) (f[ ...
- POJ1185 炮兵阵地 —— 状压DP
题目链接:http://poj.org/problem?id=1185 炮兵阵地 Time Limit: 2000MS Memory Limit: 65536K Total Submissions ...
- TZOJ 4912 炮兵阵地(状压dp)
描述 司令部的将军们打算在N*M的网格地图上部署他们的炮兵部队.一个N*M的地图由N行M列组成,地图的每一格可能是山地(用"H" 表示),也可能是平原(用"P" ...
- poj - 1185 炮兵阵地 状压DP 解题报告
炮兵阵地 Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 21553 Accepted: 8363 Description ...
- luogu 2704 炮兵阵地 状压dp
状压的基础题吧 第一次看感觉难上天,后来嘛就.. 套路:先根据自身状态筛出可行状态,再根据地图等其他限制条件筛选适合的状态加入答案 f i,j,k 分别代表 行数,本行状态,上行状态,再累加答案即可 ...
- POJ 1185 炮兵阵地 状压dp
题目链接: http://poj.org/problem?id=1185 炮兵阵地 Time Limit: 2000MS Memory Limit: 65536K 问题描述 司令部的将军们打算在N*M ...
随机推荐
- 网格动物UVA1602
题目大意 输入n,w,h(1<=n<=10,1<=w,h<=n).求能放在w*h网格里的不同的n连块的个数(平移,旋转,翻转算一种) 首先,方法上有两个,一是打表,dfs构造连 ...
- 推荐一款国产的高性价比profinet分布式IO模块
国产profinet分布式IO模块,兼容西门子PLC,可以平替西门子小型分布式IO模块,最大支持挂在32个IO,支持512个变量数据采集!采用高速背板通讯协议,轮询时间少于1MS.
- linux学习之selinux安全处理
linux在默认情况下会开启selinux,如果软件开放的端口不是selinux默认的协议端口会导致防火墙端口开放后还是无法访问.以下是解决办法. [root@localhost ~]# semana ...
- 当我们谈论算法我们在谈论什么:由疫情核酸检测想到的分治算法(Divide-and-Conquer)
原文转载自「刘悦的技术博客」https://v3u.cn/a_id_159 北京的疫情一波未平一波又起,由此看来,战"疫"将是一场旷日持久的战争,绝不能掉以轻心.轻易言胜.病毒随时 ...
- Redis 定长队列的探索和实践
vivo 互联网服务器团队 - Wang Zhi 一.业务背景 从技术的角度来说,技术方案的选型都是受限于实际的业务场景,都以解决实际业务场景为目标. 在我们的实际业务场景中,需要以游戏的维度收集和上 ...
- 大数据平台迁移实践 | Apache DolphinScheduler 在当贝大数据环境中的应用
大家下午好,我是来自当贝网络科技大数据平台的基础开发工程师 王昱翔,感谢社区的邀请来参与这次分享,关于 Apache DolphinScheduler 在当贝网络科技大数据环境中的应用. 本次演讲主要 ...
- Taurus.MVC WebAPI 入门开发教程6:全局控制器DefaultController与全局事件。
系列目录 1.Taurus.MVC WebAPI 入门开发教程1:框架下载环境配置与运行. 2.Taurus.MVC WebAPI 入门开发教程2:添加控制器输出Hello World. 3.Tau ...
- mybatis报错:java.io.IOException: Could not find resource /resources/mybatis-config.xml
原因: 这个图标的resources目录是根目录,在此目录下的文件直接写文件名即可
- 【java】学习路径16-重写Object方法(equals()等)
在平时开发中,想要比较自定义类对象中的特定成员时,我们需要逐一手动比较,非常不方便. 举个栗子,我们有两个cafe对象,我们想比较两杯咖啡的价格是否一样,一般来说我们使用getter()来比较,但是这 ...
- ping: sina.cn: Name or service not known
该方法针对Ubuntu18及以后版本. 第一次遇到ping:报错Name or service not known这个问题在百度上找了很久说的都是什么修改 /etc/resolv.conf,但每次修改 ...