[状压dp]POJ1185 炮兵阵地

中文题 题意不再赘述

对于中间这个“P” 根据dp的无后效性 我们只需考虑前面的

就变成了 只需考虑:

也就是状压前两行

具体与HDOJ的4539类似: 看HDOJ 4539

仅仅是共存状态的判断不同

 1 //#include <bits/stdc++.h>
 2 #include <cstdio>
 3 #include <cstring>
 4 #include <iostream>
 5 #include <algorithm>
 6 using namespace std;
 7 typedef long long LL;
 8
 9 int dp[2][1050][1050], mp[105][105];
10 int pos[1050], d;
11 int main()
12 {
13     int d=0;
14     for(int i=0;i<(1<<10);i++)
15         if(!(i&(i<<2)) && !(i&(i<<1)))
16             pos[d++]=i;// 预处理 一行 符合条件的
17     int n, m;
18     while(~scanf("%d%d", &n, &m))
19     {
20         int ans=0;
21         memset(mp, 0, sizeof(mp));
22         for(int i=1;i<=n;i++)
23             for(int j=0;j<m;j++)
24             {
25                 char c;
26                 cin>>c;
27                 mp[i][j]=(c==‘P‘);
28             }
29         memset(dp, 0, sizeof(dp));
30         for(int i=1;i<=n;i++)//枚举n行
31             for(int j=0;j<d && pos[j]<(1<<m);j++)
32             {
33                 int sum=0;
34                 for(int k=0;k<m;k++)//对于当前(i,k位置)该行(前面k格)是否满足
35                     if(pos[j]&1<<k)
36                         sum+=mp[i][k];
37                 for(int k=0;k<d && pos[k]<(1<<m);k++) // 枚举i-1行的状态 看能否与第i行共存
38                     if(!(pos[j]&pos[k]))
39                     {
40                         int tmp=0;
41                         for(int l=0;l<d && pos[l]<(1<<m);l++)  // 枚举i-2行的状态 看能否与第i行、第i-1行共存
42                             if(!(pos[j]&pos[l]))
43                                 tmp=max(tmp, dp[1-i&1][k][l]);
44                         dp[i&1][j][k]=tmp+sum;
45                         ans=max(ans, dp[i&1][j][k]);
46                     }
47             }
48         printf("%d\n", ans);
49     }
50     return 0;
51 }

POJ 1185

时间: 2024-10-19 00:43:45

[状压dp]POJ1185 炮兵阵地的相关文章

状压DP NOI2001 炮兵阵地

司令部的将军们打算在N × M的网格地图上部署他们的炮兵部队.一个N × M的地图由N行M列组成,地图的每一格可能是山地(用"H"表示),也可能是平原(用"P"表示),如下图.在每一格平原地形上最多可以布置一支炮兵部队(山地上不能够部署炮兵部队):一支炮兵部队在地图上的攻击范围如图中黑色区域所示: 如果在地图中的灰色所标识的平原上部署一支炮兵部队,则图中的黑色的网格表示它能够攻击到的区域:沿横向左右各两格,沿纵向上下各两格.图上其它白色网格均攻击不到.从图上可见炮兵

dp乱写2:状态压缩dp(状压dp)炮兵阵地

https://www.luogu.org/problem/show?pid=2704 题意: 炮兵在地图上的摆放位子只能在平地('P') 炮兵可以攻击上下左右各两格的格子: 而高原('H')上炮兵能够攻击到但是不能摆放 求最多能摆放的炮兵的数量 就是这个意思. 难度提高,弱省省选 一开始是想写dfs(迷之八皇后)的, 但是看到数据量100就想dp了: 因为题目n的范围给的很少n<=10,想到状压 非常明显是一个状态压缩的dp(状压dp) 其实可以当做状压的入门题目来做. 由于本行的状态是由前若

poj1185炮兵阵地状压dp

压前两行的状态很容易想到,但是 直接搞  (1<<10) * (1<<10)  空间时间都明显受不了, 但是经过高人指点,你会发现:枚举每一行可行的状态,其实并不多,预先打表处理,不用 1->(1<<10)枚举每一种状态.. 然后记忆化搜就ok了. #include <cstdio> #include <cstring> #include <cmath> #include <algorithm> #include &

[poj1185]炮兵阵地_状压dp

炮兵阵地 poj-1185 题目大意:给出n列m行,在其中添加炮兵,问最多能加的炮兵数. 注释:n<=100,m<=10.然后只能在平原的地方建立炮兵. 想法:第2到状压dp,++.这题显然是很经典的.设状态dp[i][j][k]表示第i行的状态为j,i-1行的状态为k的最多炮兵数.在转移时,枚举所有的合法炮兵排列(此处的合法数目是根据一行全为平原的时候能放置的合法炮兵数目),然后内层循环枚举dp[i-1]的i-1状态,进行特判更新即可.统计答案时,我们只需对于dp[n]的所有可能状态求最大值

poj1185:炮兵阵地(状压dp)

也算是比较基础的状压dp了,跟做过的第二道比较又稍微复杂了一点 需要记录之前两行的状态.. 统计结果也稍有不同 另外还学习了一个得到一个整数二进制位 1 的个数的位运算方法 详见代码: #include <iostream> #include <stdio.h> #include<string.h> #include<algorithm> #include<string> #include<ctype.h> using namespa

POJ 1185 炮兵阵地 状压dp

http://poj.org/problem?id=1185 经典题目不必多说,直接贴代码. 1 #include<cstdio> 2 #include<cstring> 3 #include<algorithm> 4 using namespace std; 5 6 int n, m, cnt, size; 7 int a[110], st[70], ct[70]; 8 char str[15]; 9 int f[110][70][70]; 10 void init(

状压DP [POJ 1185] 炮兵阵地

炮兵阵地 Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 19922   Accepted: 7709 Description 司令部的将军们打算在N*M的网格地图上部署他们的炮兵部队.一个N*M的地图由N行M列组成,地图的每一格可能是山地(用"H" 表示),也可能是平原(用"P"表示),如下图.在每一格平原地形上最多可以布置一支炮兵部队(山地上不能够部署炮兵部队):一支炮兵部队在地图上的攻击

POJ 1185 炮兵阵地 状压DP+离散化优化

一开始能想到的状态就只有位压两行和当前行的行号,这样无论是空间和时间都是无法接受的. 但是因为炮兵的攻击范围比较大,而且又有地形限制,每一行的状态其实不多了,打表看了一下不超过80种,离散化一下就可以随意DP了. 据说题目也可以抽象成二分图最大匹配来搞?感觉复杂度有点高 #include <cstdio> #include <cstring> #include <iostream> #include <map> #include <set> #i

POJ 1185 炮兵阵地 (状压dp 经典中的经典)

炮兵阵地 Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 21381   Accepted: 8290 Description 司令部的将军们打算在N*M的网格地图上部署他们的炮兵部队.一个N*M的地图由N行M列组成,地图的每一格可能是山地(用"H" 表示),也可能是平原(用"P"表示),如下图.在每一格平原地形上最多可以布置一支炮兵部队(山地上不能够部署炮兵部队):一支炮兵部队在地图上的攻击