题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4539

郑厂长系列故事——排兵布阵

Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)
Total Submission(s): 3289    Accepted Submission(s): 1144

Problem Description
郑厂长不是正厂长
  也不是副厂长
  他根本就不是厂长
  事实上
  他是带兵打仗的团长

  一天,郑厂长带着他的军队来到了一个n*m的平原准备布阵。
  根据以往的战斗经验,每个士兵可以攻击到并且只能攻击到与之曼哈顿距离为2的位置以及士兵本身所在的位置。当然,一个士兵不能站在另外一个士兵所能攻击到的位置,同时因为地形的原因平原上也不是每一个位置都可以安排士兵。
  现在,已知n,m 以及平原阵地的具体地形,请你帮助郑厂长计算该阵地,最多能安排多少个士兵。

Input
输入包含多组测试数据;
每组数据的第一行包含2个整数n和m (n <= 100, m <= 10 ),之间用空格隔开;
接下来的n行,每行m个数,表示n*m的矩形阵地,其中1表示该位置可以安排士兵,0表示该地形不允许安排士兵。
Output
请为每组数据计算并输出最多能安排的士兵数量,每组数据输出一行。
Sample Input
6 6 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
Sample Output
2
Source
2013腾讯编程马拉松复赛第二场(3月30日)

题解:

POJ1185 炮兵阵地此题的变形。

代码如下:

 1 #include <iostream>
 2 #include <cstdio>
 3 #include <cstring>
 4 #include <algorithm>
 5 #include <vector>
 6 #include <cmath>
 7 #include <queue>
 8 #include <stack>
 9 #include <map>
10 #include <string>
11 #include <set>
12 using namespace std;
13 typedef long long LL;
14 const double EPS = 1e-6;
15 const int INF = 2e9;
16 const LL LNF = 9e18;
17 const int MOD = 1e5;
18 const int MAXN = 1e3+10;
19
20 int row[110], sta[170], cnt[170], dp[110][170][170];
21 int main()
22 {
23     int n, m;
24     while(scanf("%d%d", &n,&m)!=EOF)
25     {
26         for(int i = 1; i<=n; i++)
27         {
28             int val;
29             row[i] = 0;
30             for(int j = 0; j<m; j++)
31             {
32                 scanf("%d", &val);
33                 row[i] += (val==0)*(1<<j);
34             }
35         }
36
37         int tot = 0;
38         for(int s = 0; s<(1<<m); s++)
39         {
40             if(!(s&(s<<2)))
41             {
42                 sta[++tot] = s;
43                 cnt[tot] = 0;
44                 for(int j = 0; j<m; j++)
45                     if(s&(1<<j))
46                         cnt[tot]++;
47             }
48         }
49
50         memset(dp, 0, sizeof(dp));
51         for(int i = 1; i<=n; i++)
52         {
53             for(int j = 1; j<=tot; j++)
54             {
55                 int s1 = sta[j];
56                 if(i>2 && (s1&row[i-2])) continue;
57                 for(int k = 1; k<=tot; k++)
58                 {
59                     int s2 = sta[k];
60                     if(i>1 && (s2&row[i-1])) continue;
61                     if(s1&(s2<<1) || (s1&(s2>>1)) ) continue;
62                     for(int t = 1; t<=tot; t++)
63                     {
64                         int s3 = sta[t];
65                         if(s3&row[i]) continue;
66                         if(s2&(s3<<1) || (s2&(s3>>1)) ) continue;
67                         if(s1&s3) continue;
68                         dp[i][k][t] = max(dp[i][k][t], dp[i-1][j][k]+cnt[t]);
69                     }
70                 }
71             }
72         }
73
74         int ans = 0;
75         for(int i = 1; i<=tot; i++)
76             for(int j = 1; j<=tot; j++)
77                 ans = max(ans, dp[n][i][j]);
78         printf("%d\n", ans);
79     }
80 }

View Code

转载于:https://www.cnblogs.com/DOLFAMINGO/p/8509361.html

HDU 4539 郑厂长系列故事——排兵布阵 —— 状压DP相关推荐

  1. HDU 4539郑厂长系列故事――排兵布阵(状压DP)

    HDU 4539  郑厂长系列故事――排兵布阵 基础的状压DP,首先记录先每一行可取的所哟状态(一行里互不冲突的大概160个状态), 直接套了一个4重循环居然没超时我就呵呵了 1 //#pragma ...

  2. hdu 4539 郑厂长系列故事——排兵布阵

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

  3. HDU 4539 郑厂长系列故事――排兵布阵(状态压缩)

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

  4. HDU 4539 郑厂长系列故事――排兵布阵

    /* 曼哈顿距离的定义是:两个点的坐标为(x1,y1),(x2,y2),两点的曼哈顿距离为|x1-x2|+|y1-y2| 题意:题上要求是两个士兵的距离不能是曼哈顿距离为2,意思就是这个点在同一行同一 ...

  5. 排兵布阵问题java语言_hdu 4539 郑厂长系列故事——排兵布阵

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

  6. 郑厂长系列故事——排兵布阵 状态压缩DP

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

  7. HDU-4539 郑厂长系列故事——排兵布阵 状态压缩DP Or 最大团

    题意:给定一个方格,然后告诉你一些规则,这些规则下方格中的有些位置是相冲突的.问在方格中最多能够放置多少个士兵. 分析:比赛时一开始就想着用状态压缩DP来搞,不过忘了相邻三行产生关系同样可以通过添加状 ...

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

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

  9. hdu-4539 郑厂长系列故事――排兵布阵(状态压缩)

    类似于poj-1185 //曼哈顿距离 d = |x1 - x2| + |y1 - y2| //解决曼哈顿距离冲突 s[i]&(s[j] << 1)||s[i]&(s[j] ...

  10. HDU4539-郑厂长系列故事——排兵布阵

    郑厂长不是正厂长 也不是副厂长 他根本就不是厂长 事实上 他是带兵打仗的团长 一天,郑厂长带着他的军队来到了一个nm的平原准备布阵. 根据以往的战斗经验,每个士兵可以攻击到并且只能攻击到与之曼哈顿距离 ...

最新文章

  1. java引用类型和值类型_[Java教程]JavaScript中值类型和引用类型的区别
  2. python运行时修改代码会怎样_python运行时修改代码的方法——monkey patch
  3. 为Envoy构建控制平面的指南-特定于域的配置API
  4. console.log打印没有效果
  5. 将整个表单设置为只读_如何将独立网站设置为制作中,阻止搜索引擎收录网站页面?...
  6. c++ 获取数据类型最大值或最小值
  7. JS 实现 jQuery的$(function(){});
  8. 【Java】DNS缓存
  9. vue-router: 路由传参
  10. raft Paxos
  11. 原创的一份游戏创意案
  12. h5/uni-app打开手机app,没有则跳转到商店下载
  13. mac电脑usb连接android手机,【已解决】安卓手机小米9如何连接到Mac电脑中去拷贝手机中图片...
  14. OpenCV(C++)图像处理基础03:读写像素、像素值修改、像素反差
  15. 十二步教你学会3d游戏建模,成功入行
  16. STL 自定义sort 前缀和差分练习
  17. 2010总结,2011展望
  18. 关于position: sticky的简单用法
  19. 【JSD2209-DAY05】for、while、数组(上)
  20. html5开发android应用

热门文章

  1. leetcode331. Verify Preorder Serialization of a Binary Tree
  2. Netty 核心组件 Pipeline 源码分析(二)一个请求的 pipeline 之旅
  3. 比特币 的 正统 ——BCH
  4. ducument.ready不生效的问题 ruby on rails
  5. 理解和使用 Unity UI 系统(canvas和CanvasScaler )
  6. CMOS checksum error-Defaults loaded 故障解决办法
  7. 如何不显示index.php,tp如何隐藏index.php
  8. gazebo模型_SLAM组合拳之六 — 创建自定义Gazebo功能包(一)
  9. python direct_Python-RabbitMQ-direct(广播模式)
  10. Linux服务器时间快8个小时,Linux系统时间快8小时解决方案