HDU 4539 郑厂长系列故事――排兵布阵(曼哈顿距离)

时间:2021-08-02 08:54:04

这虽然是中文题,然而没看懂,不懂的地方,就是在曼哈顿距离这块,网上搜索了一下,写了个程序,是测试曼哈顿距离的。

曼哈顿距离:两点(x1,y1)(x2,y2)的曼哈顿距离为|x1-x2|+|y1-y2|

测试代码:

#include <map>
#include <set>
#include <list>
#include <cmath>
#include <queue>
#include <stack>
#include <vector>
#include <cstdio>
#include <string>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std; const int INF=0x3f3f3f3f;
typedef long long ll;
typedef unsigned long long ull;
#define fi first
#define se second
#define prN printf("\n")
#define SI(N) scanf("%d",&(N))
#define SII(N,M) scanf("%d%d",&(N),&(M))
#define SIII(N,M,K) scanf("%d%d%d",&(N),&(M),&(K))
#define cle(a,val) memset(a,(val),sizeof(a))
#define rep(i,b) for(int i=0;i<(b);i++)
#define Rep(i,a,b) for(int i=(a);i<=(b);i++) char tu[60][60];
int a[100][2];
int main()
{
#ifndef ONLINE_JUDGE
// freopen("C:\\Users\\Zmy\\Desktop\\in.txt","r",stdin);
// freopen("C:\\Users\\Zmy\\Desktop\\out.txt","w",stdout);
#endif // ONLINE_JUDGE int i=2,i1=3;
int p=0;
rep(j,6)
rep(j1,6)
{
if (abs(i-j)+abs(i1-j1)==2)
{
printf("%d %d\n",j,j1);
a[p][0]=j;
a[p++][1]=j1;
}
} // i=2,i1=2;
// rep(j,6)
// rep(j1,6)
// {
// if (abs(i-j)+abs(i1-j1)==2)
// {
// printf("%d %d\n",j,j1);
// a[p][0]=j;
// a[p++][1]=j1;
// }
// } cle(tu,'.');
rep(i,p)
{ tu[a[i][0]][a[i][1]]='*';
} rep(i,6)
{
rep(j,6)
{
printf("%c ",tu[i][j]);
}
prN;
} return 0;
}

这是根据测试样例的背景写的,i,i1是所给坐标,最后输出*的地方,就是他对应的曼哈顿距离 (由图可知:曼哈顿距离就是以这个点为中心的菱形)

AC代码:

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
#define N 110
#define M 200 using namespace std; int n,m,a[N];
int dp[N][M][M],cnt,num[M],sum[M];
///dp[i][j][k] 表示第i行的j状态 i-1行的k状态 的最优解 bool ok(int x)
{
return (x&(x<<2))||(x&(x<<2));///第x-2个和x+2个位是否有人,
// 有的话就不符合条件
} int getsum(int x) ///1的个数,即放多少个兵
{
int sum=0;
while(x)
{
if(x&1)sum++;
x>>=1;
}
return sum;
} void init()
{
cnt=0;
for(int i=0; i<(1<<m); i++) ///预处理,压缩
{
if(!ok(i))
{
num[cnt]=i;
sum[cnt++]=getsum(i);
}
}
}
////二进制函数
//int two[100];
//void o_two(int n)
//{
// memset(two,0,sizeof(two));
// int p=1;
// while(n)
// {
// two[p++]=n%2;
// n/=2;
// }
// printf("Two:");
// for (int i=12;i>=1;i--)
// {
// if (i%4==0)
// printf(" ");
// printf("%d ",two[i]);
// }puts("");
//}
int main()
{
#ifndef ONLINE_JUDGE
freopen("C:\\Users\\Zmy\\Desktop\\in.txt","r",stdin);
// freopen("C:\\Users\\Zmy\\Desktop\\out.txt","w",stdout);
#endif // ONLINE_JUDGE
while(~scanf("%d%d",&n,&m))
{
memset(a,0,sizeof a);
for(int i=0; i<n; i++)
{
for(int j=0; j<m; j++)
{
int x;
scanf("%d",&x);
if(x)continue;///方便计算,把0存为1
a[i]|=(1<<j);
}
}
// for (int i=0;i<n;i++)
// o_two(a[i]);
init();///初始化了num(情况数组)和sum(个数数组)
memset(dp,0,sizeof dp);
for(int i=0; i<cnt; i++) ///处理第一行
{
if(a[0]&num[i])continue;
dp[0][i][0]=sum[i];
} ///递推,要考虑三行的情况,
for(int i=1; i<n; i++) //第一行
{
for(int j=0; j<cnt; j++)
{
if(a[i]&num[j])continue; ///第一行与原来矩阵有冲突
for(int k=0; k<cnt; k++) ///第二行
{
if(a[i-1]&num[k])continue;
if(((num[k]<<1)&num[j])||((num[k]>>1)&num[j]))continue; //i-1行
int Max=-1;
for(int l=0; l<cnt; l++) ///第三行
{
if(num[j]&num[l])continue;
if(((num[l]<<1)&num[k])||((num[l]>>1)&num[k]))continue;
Max=max(Max,dp[i-1][k][l]);
}
dp[i][j][k]=Max+sum[j];
}
}
}
int Max=-1;
for(int i=0; i<cnt; i++)
for(int j=0; j<cnt; j++)
Max=max(Max,dp[n-1][i][j]);
printf("%d\n",Max);
}
return 0;
}

  

HDU 4539 郑厂长系列故事――排兵布阵(曼哈顿距离)的更多相关文章

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

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

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

    http://acm.hdu.edu.cn/showproblem.php?pid=4539 郑厂长系列故事——排兵布阵 Time Limit: 10000/5000 MS (Java/Others) ...

  3. HDU 4539 郑厂长系列故事——排兵布阵 状压dp

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4539 郑厂长系列故事--排兵布阵 Time Limit: 10000/5000 MS (Java/O ...

  4. HDU 4539 郑厂长系列故事——排兵布阵 —— 状压DP

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4539 郑厂长系列故事——排兵布阵 Time Limit: 10000/5000 MS (Java/Ot ...

  5. POJ 1185 - 炮兵阵地 &amp&semi; HDU 4539 - 郑厂长系列故事——排兵布阵 - &lbrack;状压DP&rsqb;

    印象中这道题好像我曾经肝过,但是没肝出来,现在肝出来了也挺开心的 题目链接:http://poj.org/problem?id=1185 Time Limit: 2000MS Memory Limit ...

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

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

  7. HDU-4539郑厂长系列故事——排兵布阵(状态压缩,动态规划)

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

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

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

  9. &lbrack;状压dp&rsqb;HDOJ4539 郑厂长系列故事——排兵布阵

    中文题,题意不再赘述 对于“?”这一格,它所能攻击到的(曼哈顿距离为2的) 前方的 即“√”的四个位置 那么与此格有关的即它前方两行(即状压这两行) 首先预处理每行能满足的: i 和(i<&lt ...

随机推荐

  1. 在移动端中的flex布局

    flex布局介绍: flex布局很灵活, 这种布局我们也可以称之为弹性布局,  弹性布局的主要优势就是元素的宽或者高会自动补全; flex布局实例: 比如有两个div,一个div的宽度为100px, ...

  2. p&sol;invoke 碎片-- 对字符串的处理

    字符串在内存中的的几种风格 字符串作为参数和返回值 参考 字符串在内存中的几种风格 所谓的风格,也就是字符串在内存中的存在形式.如何存放的,占据内存的大小,还有存放顺序等.在不同的编程语言和不同的平台 ...

  3. PHP将uncode转utf8,一行代码解决问题

    在很多场合能看到unicode编码过的文字,如“\u6d3b\u52a8\u63a5\u53e3”,虽然程序会认识,但人眼无法阅读,很不方便,网络上很多人写了很多的转换函数,但是一个比一个臃肿,终于发 ...

  4. memset中的sizeof

    记录memset中的sizeof的用法, unsigned char *buff = (unsigned char*) malloc(128 * sizeof(char)); //错误的:memset ...

  5. select&lpar;&rpar;2

    只要接触过c/c++网路编程人都可能会知道select io 模式,网络书籍都说 fd_set {]} 有所限制,因为数组的长度只有64,那么超过64你就不能放,要么你就是用多线程分别实用select ...

  6. Linux 系统运行级别

    Linux运行级别从0-6,共7个.  0:关机.不能将系统缺省运行级别设置为0,否则无法启动.  1:单用户模式,只允许root用户对系统进行维护.  2:多用户模式,但不能使用NFS(相当于Win ...

  7. 新浪云SAE 关于部分函数不能使用的做法

    例如:file_put_contents("test.txt","Hello World. Testing!"); 可以这样写: file_put_conten ...

  8. java类文件

    一个.java文件中可以有很多类.不过注意以下几点: 1.public 权限的类只能有一个(也可以一个都没有,但最多只有1个) ,其他的类不能加public. 2.这个.java文件的文件名必须是pu ...

  9. Dubbo透传traceId&sol;logid的一种思路

    前言: 随着dubbo的开源, 以及成为apache*项目. dubbo越来越受到国内java developer欢迎, 甚至成为服务化自治的首选方案. 随着微服务的流行, 如何跟踪整个调用链, 成 ...

  10. Python3 图片水平镜像实现

    # -*- coding: utf-8 -*- """ Created on Sun Feb 4 12:15:38 2018 @author: markli " ...