题意:中文题。

思路,经典的状态压缩题目。

由于列长比较小,我们可以以行为阶段用状态压缩来做。

由于攻击只占两个格,这样从行的角度看,第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)的更多相关文章

  1. POJ 1185 炮兵阵地 经典的 状态压缩dp

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

  2. POJ 1185 炮兵阵地(动态规划+状态压缩)

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

  3. poj 1185 炮兵阵地 [经典状态压缩DP]

    题意:略. 思路:由于每个大炮射程为2,所以如果对每一行状态压缩的话,能对它造成影响的就是上面的两行. 这里用dp[row][state1][state2]表示第row行状态为state2,第row- ...

  4. poj -1185 炮兵阵地 (经典状压dp)

    http://poj.org/problem?id=1185 参考博客:http://poj.org/problem?id=1185 大神博客已经讲的很清楚了,注意存状态的时候是从1开始的,所以初始化 ...

  5. POJ 1185 炮兵阵地 状压dp

    题目链接: http://poj.org/problem?id=1185 炮兵阵地 Time Limit: 2000MS Memory Limit: 65536K 问题描述 司令部的将军们打算在N*M ...

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

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

  7. poj - 1185 炮兵阵地 状压DP 解题报告

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

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

    题目链接 POJ 1185 今天艾教留了一大堆线段树,表示做不动了,就补补前面的题.QAQ 这个题,我第一次写还是像前面HDU 2167那样写,发现这次影响第 i 行的还用i-2行那样,那以前的方法就 ...

  9. POJ - 1185 炮兵阵地 (插头dp)

    题目链接 明明是道状压dp的题我为啥非要用插头dp乱搞啊 逐行枚举,设dp[i][S]为枚举到第i个格子时,状态为S的情况.S为当前行上的“插头”状态,每两个二进制位表示一个格子,设当前格子为(x,y ...

随机推荐

  1. OA系统部门结构树

    public class DepartmentUtils { /** * @param topList 顶级部门列表 * @param removeId 删除部门的id * @return */ pu ...

  2. PRIMARY LANGUAGE ID not a number

    用vs2010修改别人的源代码(估计是vc6下的)  .RC 文件,报错:  1>.RC(8): error RC2144: PRIMARY LANGUAGE ID not a number 1 ...

  3. hdu 1026 Ignatius and the Princess I (bfs+记录路径)(priority_queue)

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=1026 Problem Description The Princess has been abducted ...

  4. python 练习 29

    Python Number 数据类型用于存储数值. 数据类型是不允许改变的,这就意味着如果改变 Number 数据类型的值,将重新分配内存空间. 以下实例在变量赋值时 Number 对象将被创建: v ...

  5. Python 练习 11

    #!/usr/bin/python # -*- coding: UTF-8 -*- import math for i in range(10000): #转化为整型值 x = int(math.sq ...

  6. hdu------2488Tornado(几何)

    Tornado Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Sub ...

  7. Java 集合系列 15 Map总结

    java 集合系列目录: Java 集合系列 01 总体框架 Java 集合系列 02 Collection架构 Java 集合系列 03 ArrayList详细介绍(源码解析)和使用示例 Java ...

  8. Java 集合系列 05 Vector详细介绍(源码解析)和使用示例

    java 集合系列目录: Java 集合系列 01 总体框架 Java 集合系列 02 Collection架构 Java 集合系列 03 ArrayList详细介绍(源码解析)和使用示例 Java ...

  9. js创建table表格

    //js创建table表格var tr;var cell;for(var i=0;i<10;i++){ //创建一个tr tr=document.createElement('tr'); doc ...

  10. CommonJS规范(转)

    概述 CommonJS是服务器端模块的规范,Node.js采用了这个规范. 根据CommonJS规范,一个单独的文件就是一个模块.加载模块使用require方法,该方法读取一个文件并执行,最后返回文件 ...