[Poj1185][Noi2001]炮兵阵地(状压dp)
| Time Limit: 2000MS | Memory Limit: 65536K | |
| Total Submissions: 29476 | Accepted: 11411 |
Description

如果在地图中的灰色所标识的平原上部署一支炮兵部队,则图中的黑色的网格表示它能够攻击到的区域:沿横向左右各两格,沿纵向上下各两格。图上其它白色网格均攻击不到。从图上可见炮兵的攻击范围不受地形的影响。
现在,将军们规划如何部署炮兵部队,在防止误伤的前提下(保证任何两支炮兵部队之间不能互相攻击,即任何一支炮兵部队都不在其他支炮兵部队的攻击范围内),在整个地图区域内最多能够摆放多少我军的炮兵部队。
Input
接下来的N行,每一行含有连续的M个字符('P'或者'H'),中间没有空格。按顺序表示地图中每一行的数据。N <= 100;M <= 10。
Output
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)的更多相关文章
- [POJ1185][NOI2001]炮兵阵地 状压DP
题目链接:http://poj.org/problem?id=1185 很裸的状压,考虑对于一行用二进制储存每一种的状态,但是状态太多了做不了. 观察到有很多状态都是不合法的,于是我们预处理出合法的状 ...
- 洛谷P2704 [NOI2001]炮兵阵地 [状压DP]
题目传送门 炮兵阵地 题目描述 司令部的将军们打算在N*M的网格地图上部署他们的炮兵部队.一个N*M的地图由N行M列组成,地图的每一格可能是山地(用“H” 表示),也可能是平原(用“P”表示),如下图 ...
- P2704 [NOI2001]炮兵阵地 (状压DP)
题目: P2704 [NOI2001]炮兵阵地 解析: 和互不侵犯一样 就是多了一格 用\(f[i][j][k]\)表示第i行,上一行状态为\(j\),上上行状态为\(k\)的最多的可以放的炮兵 发现 ...
- [NOI2001]炮兵阵地 状压DP
题面: 司令部的将军们打算在N*M的网格地图上部署他们的炮兵部队.一个N*M的地图由N行M列组成,地图的每一格可能是山地(用“H” 表示),也可能是平原(用“P”表示),如下图.在每一格平原地形上最多 ...
- 【POJ1185】炮兵阵地 状压DP
感觉总是被一些SB错误所困扰... 差不多还是(模板题)注意数组空间的大小,和对于合法状态的判断. f[i][j][k]=max(f[i][k][j],f[i-1][l][k]+num[j]) (f[ ...
- POJ1185 炮兵阵地 —— 状压DP
题目链接:http://poj.org/problem?id=1185 炮兵阵地 Time Limit: 2000MS Memory Limit: 65536K Total Submissions ...
- TZOJ 4912 炮兵阵地(状压dp)
描述 司令部的将军们打算在N*M的网格地图上部署他们的炮兵部队.一个N*M的地图由N行M列组成,地图的每一格可能是山地(用"H" 表示),也可能是平原(用"P" ...
- poj - 1185 炮兵阵地 状压DP 解题报告
炮兵阵地 Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 21553 Accepted: 8363 Description ...
- luogu 2704 炮兵阵地 状压dp
状压的基础题吧 第一次看感觉难上天,后来嘛就.. 套路:先根据自身状态筛出可行状态,再根据地图等其他限制条件筛选适合的状态加入答案 f i,j,k 分别代表 行数,本行状态,上行状态,再累加答案即可 ...
- POJ 1185 炮兵阵地 状压dp
题目链接: http://poj.org/problem?id=1185 炮兵阵地 Time Limit: 2000MS Memory Limit: 65536K 问题描述 司令部的将军们打算在N*M ...
随机推荐
- Vue.js Extension Pack 和 jsconfig.json 可以定位跳转到@开头的路径等自定义路径
Vue.js Extension Pack | vsCode插件 可以定位跳转到@开头的路径等自定义路径 webpack自定义别名后,VScode路径提示问题 //tsconfig.json 或者 j ...
- iview upload on-format-error 事件 在 before-upload 事件 之后,导致在before里面阻止上传后,监测事件失效,需要自己手工写
iview upload on-format-error 事件 在 before-upload 事件 之后,导致在before里面阻止上传后,监测事件失效,需要自己手工写
- Bug的定义和分类
什么是BUG 使用人工或自动手段,来运行或测试某个系统的过程.其目的在于检验它是否满足规定的需求或弄清预期结果与实际结果之间的差别 BUG分类 完全没有实现的功能 基本实现了用户需要的功能,但是运行时 ...
- 《3+1团队》【Alpha】Scrum meeting 1
项目 内容 这个作业属于哪个课程 任课教师博客主页链接 这个作业的要求在哪里 作业链接地址 团队名称 3+1团队 团队博客地址 https://home.cnblogs.com/u/3-1group ...
- 内置函数filter和map
filter filter()函数接收一个函数 f 和一个list,这个函数 f 的作用是对每个元素进行判断,返回 True或 False,filter()根据判断结果自动过滤掉不符合条件的元素,返回 ...
- grep取缩写|awk两个文件取交集
#!/bin/sh les species_latinName_abbr.txt|grep -E 'Aptenodytes|Gavia|Phoenicopterus|Chlamydotis|Phaet ...
- c# xml本地化用法
1.普通格式 2.占位符格式 注意事项: 1.Pascal命名法 2.key只是key,中间不需要空格,value可以空格 3.占位符左右两边分别空一格
- OI Journal
佛系更新,哪天想起来就写点. 10.11 班主任硬灌的鸡汤真香 qtmd,简直就是硬扯,说怎么怎么着说不定就能多拿一分两分,一分两分就能割掉好多人 ......螺旋懵圈状,我表示硬憋着不笑 HIAHI ...
- [CF] 950B Intercepted Message
B. Intercepted Message time limit per test1 second memory limit per test512 megabytes inputstandard ...
- python实现快速排序、冒泡
快速排序:首先任意选取一个数据(通常选用数组的第一个参数)作为关键数据,然后将比它小的数放在它前面,比它大的数放在后面,这个过程称之为快速排序 def quick_sort(l): if len(l) ...