炮兵阵地
Time Limit: 2000MS   Memory Limit: 65536K
Total Submissions: 29476   Accepted: 11411

Description


司令部的将军们打算在N*M的网格地图上部署他们的炮兵部队。一个N*M的地图由N行M列组成,地图的每一格可能是山地(用"H" 表示),也可能是平原(用"P"表示),如下图。在每一格平原地形上最多可以布置一支炮兵部队(山地上不能够部署炮兵部队);一支炮兵部队在地图上的攻击范围如图中黑色区域所示: 

如果在地图中的灰色所标识的平原上部署一支炮兵部队,则图中的黑色的网格表示它能够攻击到的区域:沿横向左右各两格,沿纵向上下各两格。图上其它白色网格均攻击不到。从图上可见炮兵的攻击范围不受地形的影响。 
现在,将军们规划如何部署炮兵部队,在防止误伤的前提下(保证任何两支炮兵部队之间不能互相攻击,即任何一支炮兵部队都不在其他支炮兵部队的攻击范围内),在整个地图区域内最多能够摆放多少我军的炮兵部队。 

Input


第一行包含两个由空格分割开的正整数,分别表示N和M; 
接下来的N行,每一行含有连续的M个字符('P'或者'H'),中间没有空格。按顺序表示地图中每一行的数据。N <= 100;M <= 10。

Output


仅一行,包含一个整数K,表示最多能摆放的炮兵部队的数量。

Sample Input


PHPP
PPHH
PPPP
PHPP
PHHP

Sample Output



分析:


m只有10,又是这种棋盘里放东西类似八皇后的问题。状压是肯定的。

f[i][j]表示第i排,状态为j,但是我们发现了,不止上一排可以影响,上上一排也可以

所以定义状态f[i][j][k] 第i排,当前状态为k,上一排状态为j,可以由f[i - 1][l][j] 转移

发现复杂度变成了O(n * ((2 ^ m)^ 3)),是过不了的,其实我们发现一排里如果有两个间隔是小于等于2的,是明显不合法的,可以提前处理处理出单独一排合法状态,发现最大也只有60

于是复杂度变成了O(n * (60 ^ 3)),就可以过了。

AC代码:


# include <iostream>
# include <cstdio>
# include <cstring>
using namespace std;
const int N = ;
int dp[][N][N];
int n,m,data,now,cnt;
int stack[N][],f[N],ans;
char str[N];
int lowbit(int k){
return k & -k;
}
void work(){
for(int i = ;i < data;i++){
int pre = lowbit(i),r = i - pre;
bool flag = true;
int num = ;
if(pre)num++;
while(r){
if(lowbit(r) / pre <= ){
flag = false;
break;
}
pre = lowbit(r);
r -= pre;
num++;
}
if(flag)stack[cnt][] = i,stack[cnt++][] = num;
}
}
int main(){
scanf("%d %d",&n,&m);
data = << m;
work();
memset(dp[now],-,sizeof dp[now]);
dp[now][][] = ;
for(int i = ;i < n;i++){
scanf("%s",str);
for(int j = ;j < m;j++){
if(str[j] == 'H')f[i] |= ( << j);
}
}
for(int i = ;i < n;i++){
now ^= ;
memset(dp[now],-,sizeof dp[now]);
for(int j = ;j < cnt;j++){
for(int k = ;k < cnt;k++){
if(dp[now ^ ][j][k] == -){
continue;
}
for(int l = ;l < cnt;l++){
if(stack[l][] & f[i])continue;
if((stack[j][] | stack[k][]) & stack[l][])continue;
dp[now][k][l] = max(dp[now][k][l],dp[now ^ ][j][k] + stack[l][]);
}
}
}
}
for(int i = ;i < cnt;i++){
for(int j = ;j < cnt;j++){
ans = max(ans,dp[now][i][j]);
}
}
printf("%d\n",ans);
}

[Poj1185][Noi2001]炮兵阵地(状压dp)的更多相关文章

  1. [POJ1185][NOI2001]炮兵阵地 状压DP

    题目链接:http://poj.org/problem?id=1185 很裸的状压,考虑对于一行用二进制储存每一种的状态,但是状态太多了做不了. 观察到有很多状态都是不合法的,于是我们预处理出合法的状 ...

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

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

  3. P2704 [NOI2001]炮兵阵地 (状压DP)

    题目: P2704 [NOI2001]炮兵阵地 解析: 和互不侵犯一样 就是多了一格 用\(f[i][j][k]\)表示第i行,上一行状态为\(j\),上上行状态为\(k\)的最多的可以放的炮兵 发现 ...

  4. [NOI2001]炮兵阵地 状压DP

    题面: 司令部的将军们打算在N*M的网格地图上部署他们的炮兵部队.一个N*M的地图由N行M列组成,地图的每一格可能是山地(用“H” 表示),也可能是平原(用“P”表示),如下图.在每一格平原地形上最多 ...

  5. 【POJ1185】炮兵阵地 状压DP

    感觉总是被一些SB错误所困扰... 差不多还是(模板题)注意数组空间的大小,和对于合法状态的判断. f[i][j][k]=max(f[i][k][j],f[i-1][l][k]+num[j]) (f[ ...

  6. POJ1185 炮兵阵地 —— 状压DP

    题目链接:http://poj.org/problem?id=1185 炮兵阵地 Time Limit: 2000MS   Memory Limit: 65536K Total Submissions ...

  7. TZOJ 4912 炮兵阵地(状压dp)

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

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

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

  9. luogu 2704 炮兵阵地 状压dp

    状压的基础题吧 第一次看感觉难上天,后来嘛就.. 套路:先根据自身状态筛出可行状态,再根据地图等其他限制条件筛选适合的状态加入答案 f i,j,k 分别代表 行数,本行状态,上行状态,再累加答案即可 ...

  10. POJ 1185 炮兵阵地 状压dp

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

随机推荐

  1. 数据源引用 java:/comp/env

      编辑 删除 数据源引用 java:/comp/env 2012-01-28 15:59   ENC的概念: The application component environment is ref ...

  2. 应用程序员眼中的数据库管理系统:API+数据库语言

    应用程序员眼中的数据库管理系统:API+数据库语言 sqlite3_open_v2 https://www.cnblogs.com/cchust/p/5121559.html

  3. java-基于泛型和反射机制的通用比较器实现

    一.前言 Java的比较器是用来对List集合进行排序用的,分为内部比较器和外部比较器两类 内部比较器:被排序的类要 implements Comparable 类,并实现compareTo方法. 外 ...

  4. 自己封装一个readline函数实现服务器客户端回射

    实现的功能:一次只能读取一行,客户端输入之后,一回车,马上字符串传到服务器端并显示在终端,然后服务器端将字符串又传回给客户端. 服务器端可以接收多个客户端的连接请求,并fork一个子进程来进行服务. ...

  5. QT+ 使用标准对话框+关于对话框+问题对话框+文件对话框

    #include "mainwindow.h" #include <QMenuBar> #include <QMenu> #include <QAct ...

  6. sqlserver生成脚本

    1.只生成数据 2.只生成架构 3.生成数据和架构

  7. loj6063 Shadow

    题目描述 题解: 显然凸多面体投下来一定是个凸多边形. 对于$30$分,直接投到$x-y$平面上即可. 对于$100$分,考虑搞出平面的一般式方程$ax+by+cz+d=0$. 给出平面上三个点$A, ...

  8. Python自动化测试框架——概述

    #使用import import unittest #测试用例TestCase ''' 一个测试用例时一个完整的测试流程,包括了环境准备SetUp,测试执行Run,测试环境还原TearDown 一个测 ...

  9. Go:channel

    一.channel 在 Go 语言里,不仅可以使用原子函数和互斥锁来保证对共享资源的安全访问以及消除竞争状态,还可以使用 channel,通过发送和接收需要共享的资源,在 goroutine 之间做同 ...

  10. MySQL 初识

    一.MySQL介绍: MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品.MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,M ...