题目链接:https://cn.vjudge.net/contest/276236#problem/B

题目大意:略

 具体思路:和我的上一篇写状压dp的思路差不多,不过就是这个题相当于上一个题的升级版,变成了左右,上下都会有限制,并且限制的步数是2,观察数据范围,如果按照上一个题的话,如果要是计算正确的范围取值的话,肯定会超时,所以我们可以先将所有的满足的情况先筛选出来,就算m取到10,总共的情况也就是60种,这样复杂度就大大的降下来了。

我们可以先预处理第一行和第二行,这样的话,我们就可以直接从第三行进行操作了,如果只是预处理第一行的话,第二行在往上走的时候,会取到第0行,而这一行我们是没有赋值的,所以我们应该预处理第一行和第二行。从第3行就可以直接进行操作了(就因为这个问题搞了一晚上。。。)。

我们开一个三维的dp数组,dp[i][j][k]。i代表的是第i行,j代表的是第i行取了哪种情况,k代表的是第i-1行的取值。

按道理来讲,我们应该一次比较三行的,可是为什么只是处理了两行?

因为我们在处理第i-1行的时候,我们比较的是dp[i-1][k][t]。这里的t是第i-2行,我们在处理第i行的时候就是按照一次比较三行来的,不过第三行的比较是通过第i-2行来进行比较的。

AC代码:

  1. #include<iostream>
  2. #include<cmath>
  3. #include<stack>
  4. #include<stdio.h>
  5. #include<algorithm>
  6. #include<queue>
  7. using namespace std;
  8. # define inf 0x3f3f3f3f
  9. # define ll long long
  10. const int maxn = +;
  11. char str[maxn];
  12. int a[maxn],ok[maxn],num[maxn];
  13. int dp[maxn][maxn][maxn];
  14. int cal(int t){
  15. int ans=;
  16. while(t){
  17. ans+=(t&);
  18. t>>=;
  19. }
  20. return ans;
  21. }
  22. int main()
  23. {
  24. int n,m;
  25. scanf("%d %d",&n,&m);
  26. for(int i=; i<=n; i++)
  27. {
  28. scanf("%s",str+);
  29. for(int j=; j<=m; j++)
  30. {
  31. if(str[j]=='P')
  32. a[i]=(a[i]<<)+;
  33. else
  34. a[i]=(a[i]<<)+;
  35. }
  36. }
  37. int maxstate=(<<m)-;
  38. int ans=;
  39. for(int i=; i<=maxstate; i++)
  40. {
  41. if(((i<<)&i)==&&(((i>>)&i)==)&&(((i>>)&i)==)&&(((i>>)&i)==))//把合理的情况筛选出来。
  42. {
  43. ok[++ans]=i;
  44. num[ans]=cal(i);//记录一下当前的合理情况的能放的炮弹个数记录下来。
  45. }
  46. }
  47. int maxx=;
  48. for(int i=;i<=ans;i++){
  49. if(((ok[i]&a[])==ok[i]))
  50. dp[][i][]=num[i];
  51. maxx=max(maxx,dp[][i][]);
  52. }
  53. for(int i=;i<=ans;i++){
  54. if((ok[i]&a[])==ok[i]){
  55. for(int j=;j<=ans;j++){
  56. if(((ok[j]&ok[i])==)&&((ok[j]&a[])==ok[j])){
  57. dp[][i][j]=max(dp[][i][j],dp[][j][]+num[i]);
  58. maxx=max(maxx,dp[][i][j]);
  59. }
  60. }
  61. }
  62. }
  63. for(int i=;i<=n;i++){
  64. for(int j=;j<=ans;j++){
  65. if((ok[j]&a[i])==ok[j]){
  66. for(int k=;k<=ans;k++){
  67. if(((ok[j]&ok[k])==)&&((ok[k]&a[i-])==ok[k])){
  68. for(int l=;l<=ans;l++){
  69. if(((ok[l]&ok[k])==)&&((ok[l]&ok[j])==)&&((ok[l]&a[i-])==ok[l])){//在枚举第i-2行的时候,还需要和第i行和第i-1行进行比较。
  70. dp[i][j][k]=max(dp[i][j][k],dp[i-][k][l]+num[j]);
  71. maxx=max(maxx,dp[i][j][k]);
  72. }
  73. }
  74. }
  75. }
  76. }
  77. }
  78. }
  79. printf("%d\n",maxx);
  80. return ;
  81.  
  82. }

状压dp(B - 炮兵阵地 POJ - 1185 )的更多相关文章

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

    https://www.luogu.org/problem/show?pid=2704 题意: 炮兵在地图上的摆放位子只能在平地('P') 炮兵可以攻击上下左右各两格的格子: 而高原('H')上炮兵能 ...

  2. 状压DP之炮兵阵地

    题目 原题来自:\(NOI 2001\) 司令部的将军们打算在\(N*M\) 的网格地图上部署他们的炮兵部队.一个\(N*M\)的地图由\(N\)行\(M\)列组成,地图的每一格可能是山地(用 H表示 ...

  3. [状压dp]POJ1185 炮兵阵地

    中文题 题意不再赘述 对于中间这个“P” 根据dp的无后效性 我们只需考虑前面的 就变成了 只需考虑: 也就是状压前两行 具体与HDOJ的4539类似: 看HDOJ 4539 仅仅是共存状态的判断不同 ...

  4. 状压DP初识~~炮兵阵地

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

  5. 炮兵阵地 POJ 1185

    n*m P 和 M P可以放人 M不行 人不能相互打到 问最多可以放多少人 #include<stdio.h> #include<algorithm> #include< ...

  6. 炮兵阵地 - POJ 1185(状态压缩)

    分析:先枚举出来所有的合法状态(当N=10的时候合法状态最多也就60种),用当前状态匹配上一行和上上一行的状态去匹配,看是否可以.....复杂度100*60*60*60,也可以接受. 代码如下: == ...

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

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

  8. POJ 1185 炮兵阵地 【状压DP】

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

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

    题目链接 题意 : 中文题不详述. 思路 :状压DP,1表示该位置放炮弹,0表示不放.dp[i][j][k],代表第 i 行的状态为k时第i-1行的状态为 j 时放置的最大炮弹数.只是注意判断的时候不 ...

随机推荐

  1. 计算机网络【10】—— Cookie与Session

    一.cookie 和session 的区别 a.cookie数据存放在客户的浏览器上,session数据放在服务器上. b.cookie不是很安全,别人可以分析存放在本地的COOKIE并进行COOKI ...

  2. 计算机网络【3】—— IP地址分类与子网划分

    一.IP地址分类

  3. 【Linux笔记】在后台执行scp,实现服务器间无密码文件拷贝。

    远程备份大容量时常会有这样的情形:从远程备份的文件很大,需要很长时间,想在退出ssh后程序依然能继续在后台下载,可以通过建立服务器间安全信息关系和nohup的方式解决. 有两台服务器:A服务器IP 1 ...

  4. 【CSS】规范大纲

    文件规范: 文件分类 : 通用类 :业务类. 文件引入:行内样式(不推荐):外联引入:内联引入.(避免使用Import引入) 文件本身:文件名. 编码:UTF-8. 注释规范: 块状注释:统一缩进,在 ...

  5. centOS基本操作和命令(更新)

    1.文字输入和图形界面切换 CTRL+ALT+(F1~F6)为切换至文字输入,分别对应六个不同输入界面,可用以不同账号:CTRL+ALT+F7为切换至图形界面 2.修改时区 date -R date ...

  6. c++11 函数模板的默认模板参数

    c++11 函数模板的默认模板参数 #define _CRT_SECURE_NO_WARNINGS #include <iostream> #include <string> ...

  7. Cobalt Strike 3.13的新功能

    Cobalt Strike 3.13现已推出.此版本添加了TCP Beacong,进程参数欺骗,并将Obfuscate和Sleep功能扩展到SMB和TCP Beacons. TCP Beacon Co ...

  8. 单点登录(五)-----遇到问题-----cas server 源码部署tomcat运行报错BeanCreationException:Error creating bean with name 's

    我们在上一篇文章已经解决了把下载好的cas server源码部署到tomcat缺少子项目编辑文件或者jar包导致找不到class报错的问题 单点登录(四)-----遇到问题-----cas serve ...

  9. Android中用GridView实现九宫格的两种方法(转)

    Android中用GridView实现九宫格的两种方法http://blog.csdn.net/shakespeare001/article/details/7768455 1.传统办法:实现一个继承 ...

  10. python之旅:网络基础之网络协议篇

    一.操作系统基础 操作系统:(Operating System,简称OS)是管理和控制计算机硬件与软件资源的计算机程序,是直接运行在“裸机”上的最基本的系统软件,任何其他软件都必须在操作系统的支持下才 ...