【题意】

  给定一张n*m的图,每个位置要么是P,要么是H。P的位置可以放炮兵,H则不行。炮兵会朝四个方向,距离2个单位的方格进行攻击,求在没有炮兵互伤的情况下,最多能放的炮兵数量。

【题解】

  这道题死坑。

  一开始知道是状压dp。但是状态想的比较麻烦,写了半天没写出来。

  看了网上其它神犇的题解,发现状态很简单:DP[I][J][K],表示当前为第I行,第I行状态为J,第I-1状态为K,状态转移方程比较好想的。

  不过每一行无脑算状态有最多大概1000种,状态显然存不下。考虑一下题目的限制,估算一下每一行的合法状态不超过100个吧。于是先预处理出合法状态,再标一下号就行了。

  其实难点还是在状态的构造吧(可能我比较脑残)。

  时间复杂度O(n*k^3),k表示状态数。

【代码】

 1 #include <iostream>
 2 #include <cstdio>
 3 #include <algorithm>
 4 #define N 105
 5 using namespace std;
 6 pair <int,int> p[N][N];
 7 int n,m,ans,dp[N][N][N],x,y,z,len[N];
 8 char a[N][N];
 9 void dfs(int i,int t,int s,int k)
10 {
11     if (t==m)
12     {
13         p[i][++len[i]]=make_pair(s,k);
14         return;
15     }
16     dfs(i,t+1,s<<1,k);
17     if (a[i][t+1]=='P' && (s&3)==0)    dfs(i,t+1,(s<<1)+1,k+1);
18 }
19 int main()
20 {
21     cin>>n>>m;
22     for (int i=1;i<=n;++i)
23     {
24         cin>>a[i]+1;    dfs(i,0,0,0);
25     }
26     len[0]=1;
27     for (int i=1;i<=len[1];++i)
28         dp[1][1][i]=p[1][i].second;
29     ans=0;
30     for (int i=2;i<=n;++i)
31         for (int j=1;j<=len[i-2];++j)
32             for (int k=1;k<=len[i-1];++k)
33             {
34                 x=p[i-2][j].first;
35                 y=p[i-1][k].first;
36                 if ((x&y))    continue;
37                 for (int o=1;o<=len[i];++o)
38                 {
39                     z=p[i][o].first;
40                     if ((x&z)||(y&z)) continue;
41                     dp[i][k][o]=max(dp[i][k][o],dp[i-1][j][k]+p[i][o].second);
42                     if (i==n)    ans=max(ans,dp[i][k][o]);
43                 }
44             }
45     cout<<ans<<endl;
46     return 0;
47 }

View Code

转载于:https://www.cnblogs.com/Bleacher/p/6857556.html

【NOI2001】炮兵阵地相关推荐

  1. C++ 洛谷 P2704 [NOI2001]炮兵阵地

    P2704 [NOI2001]炮兵阵地 没学状压DP的看一下 此题意思很简单,如下图,就是十字架上的不能有两个点放炮兵. 在做此题前,先做一下玉米田 玉米田题解 分析: 而m即一行的个数小于等于10, ...

  2. 洛谷 P2704 [NOI2001]炮兵阵地

    题目 题目描述 司令部的将军们打算在N*M的网格地图上部署他们的炮兵部队.一个N*M的地图由N行M列组成,地图的每一格可能是山地(用"H" 表示),也可能是平原(用"P& ...

  3. [NOI2001]炮兵阵地

    Description 司令部的将军们打算在N*M的网格地图上部署他们的炮兵部队.一个N*M的地图由N行M列组成,地图的每一格可能是山地(用"H"  表示), 也可能是平原(用&q ...

  4. 洛谷P2704 [NOI2001]炮兵阵地(状压dp)

    题目描述 司令部的将军们打算在N*M的网格地图上部署他们的炮兵部队.一个N*M的地图由N行M列组成,地图的每一格可能是山地(用"H" 表示),也可能是平原(用"P&quo ...

  5. 2022-5-20 吃月饼(something wrong), 数塔取数问题, 制铁棒, 子段统计, 炮兵阵地

    1. 吃月饼 有一块月饼,是正三角形的,又被分割成了许多块小正三角形的月饼,里面有若干块被吃掉了.现在想要在这块月饼中再找一个由小正三角形月饼的正三角形月饼,而且要求面积最大的. 样例解释: 大月饼的 ...

  6. POJ 1185 炮兵阵地 (状压DP)

    炮兵阵地 Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 14869   Accepted: 5575 Description ...

  7. hdu4539 郑厂长系列故事——排兵布阵 + POJ1158 炮兵阵地

    题意: 郑厂长系列故事--排兵布阵 Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Other ...

  8. poj 1185 NYOJ 85 炮兵阵地(状态压缩dp)

    炮兵阵地 时间限制:2000 ms  |  内存限制:65535 KB 难度:6 描述 司令部的将军们打算在N*M的网格地图上部署他们的炮兵部队.一个N*M的地图由N行M列组成,地图的每一格可能是山地 ...

  9. POJ1185 炮兵阵地 状压DP

    炮兵阵地 Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 31819   Accepted: 12295 Descriptio ...

  10. 状压dp之二之三 炮兵阵地/玉米田 By cellur925

    一.简单的状压dp 玉米田 题目描述 Farmer John has purchased a lush new rectangular pasture composed of M by N (1 ≤ ...

最新文章

  1. Nature:何胜洋和辛秀芳组发表植物叶际微生物组稳态机制
  2. 6分钟完成ImageNet训练,NVIDIA创下六项AI性能新记录!
  3. hdu oj 2020 绝对值排序
  4. java消费kafka数据之后,进行堆积之后在插入数据库
  5. P6295 有标号 DAG 计数(多项式指数函数对数函数/二项式反演/动态规划/生成函数)
  6. php快速学习方法,php快速入门学习方法
  7. rough and crude
  8. 数据结构与算法面试题80道(32)
  9. PDT + Xdebug 调试 PHP
  10. Pandas 文本数据方法 findall( )
  11. android模拟器mac版本下载,TapTap安卓模拟器for Mac-TapTap模拟器Mac版下载 V1.8.3-PC6苹果网...
  12. the JDBC Driver has been forcibly unregistered问题解决
  13. c语言某年某月某日的天数,输入某年某月某日,判断这一天是这一年的第几天...
  14. 猜数游戏,随机生成一个1~100的数进行猜测。
  15. A Surface Defect Detection Method Based on Positive Samples
  16. 跑步时戴什么耳机好、推荐几款专业跑步的耳机
  17. KVM内存管理(三)—— KSM操作实践
  18. 影视剪辑,什么是蒙太奇,蒙太奇的含义
  19. LeetCode二维子矩阵的和
  20. 达达java面试_达达面试经验

热门文章

  1. 怎么查看电脑有没有python_python人工智能爬虫系列:怎么查看python版本_电脑计算机编程入门教程自学...
  2. java汽车管理系统_坑爹!花费2亿耗时2年,网站没建完Java都写不好,顶级咨询公司埃森哲被告上法庭...
  3. excel分段排序_学会这个神操作,报表填报不再五花八门,效率远超Excel
  4. 操作失败10秒内未完成启动服务mysql_01-MySQL 命令行-cmd用法-未完成
  5. 利用DHT22和Arduino测量温湿度并显示在串口和OLED显示屏上
  6. (dijkstra算法+多权值)最短路径问题
  7. java 06_JAVA06 数组
  8. java 整数变负数_一文帮你读懂Java整数的存储原理
  9. lamp 安装 mysql_linux lamp之离线安装mysql
  10. oracle12c 删除pdb用户,oracle 12c pdb测试:创建、开关、删除