【题目描述】

小 Z 的爸爸是一位通信工程师,他所在的通信公司最近接到了一个新的通 信工程建设任务,他们需要在 C 城建设一批新的基站。 C 城的城市规划做得非常好,整个城市被规整地划分为 8 行 8 列共 64 个街 区,现在已知新基站需要建设在哪些街区,用字符“#”表示,而不需要建设基 站的街区用“.”表示。 爸爸告诉小 Z 说,建设基站最耗时的是基站两两之间互相通信的调试,每 建设一个新的基站,需要确保其与其他已经建好的基站之间能互相通信,若两 个基站的坐标分别为(x1,y1)和(x2,y2),则调试所需时间大概为 max(|x1- x2|,|y1-y2|),而一个基站的总调试时间为与其他已经建好的基站的调试时间 中的最大值。现在爸爸想考考小 Z,看小 Z 能否计算出如何设计建设基站的顺 序,使得总的调试时间尽量少?

【输入格式】

输入一个 8 行 8 列的矩阵,全部由“#”和“.”组成。

【输出格式】

输出一个整数,表示花费的最少时间。

【样例输入一】

........

........

...#....

.#......

.......#

........

........

........

【样例输出一】

8

容易想到,应该“先中间后两边”。更严格地说,现在要把连续的一段格子中的鹅卵 石摆放完成,那么把目标位置处于最左边或者最右边的鹅卵石最后放,一定不会更差。 下面稍许做些说明:不妨考虑这样一种情况, 格子 L~R 中有些格子要放鹅卵石,而且格子 L 和 R 一定要放(下面把目标位置为 x 的鹅 卵石称为鹅卵石 x)。假如你给我一个方案, 鹅卵石 L 和鹅卵石 R 都不是最后放,那么, 把这个方案中鹅卵石 L、R 中后放的那一个 与最后放的那个鹅卵石交换顺序,答案不会 变差。也就是说,让鹅卵石 L 或者鹅卵石 R 最后放是不会错过最优解的。(如图 2) 于是,一维的情况就可以使用区间动态 规划,每次决策是让最左边还是让最右边的 鹅卵石最后放,剩下的部分就变成了一个子 问题。 回到原题。由一维的情况,自然地会有如下猜想:放鹅卵石应该“先中间后四周”。 或者说,考虑一个矩形区域,(x1, y1)为左上角,(x2, y2)为右下角,那么,考虑让某一条边 上的鹅卵石最后放,代价不会变大。仔细想想这也不难说明。(如图 3) 这样我们就可以进行动态规划了。枚举把哪一条边上的鹅卵石最后放,余下的便是子 问题。

代码:

#include<algorithm>
#include<cstring>
#include<iostream>
#include<cstdio>
using namespace std;
char mp[11][11];
int f[11][11][11][11],tu[11][11];
int jue(int x){return x>0?x:-x;}
int suan(int x1,int y1,int x2,int y2,int i1,int j1,int i2,int j2)
{
int res=0;
for(int i=i1;i<=i2;++i)
for(int j=j1;j<=j2;++j)
res+=(tu[i][j])*max(max(jue(i-x1),jue(i-x2)),max(jue(j-y1),jue(j-y2)));
return res;
}
int dfs(int x1,int y1,int x2,int y2)
{
if(x1>x2||y1>y2)return 0;
if(f[x1][y1][x2][y2]!=-1) return f[x1][y1][x2][y2];
int &res = f[x1][y1][x2][y2];
res = suan(x1,y1,x2,y2,x1,y1,x1,y2)+dfs(x1+1,y1,x2,y2);
res = min(res,suan(x1,y1,x2,y2,x2,y1,x2,y2)+dfs(x1,y1,x2-1,y2));
res = min(res,suan(x1,y1,x2,y2,x1,y1,x2,y1)+dfs(x1,y1+1,x2,y2));
res = min(res,suan(x1,y1,x2,y2,x1,y2,x2,y2)+dfs(x1,y1,x2,y2-1));
return res;
}
int main()
{
freopen("station.in","r",stdin);
freopen("station.out","w",stdout);
memset(f,-1,sizeof(f));
for(int i=1;i<=8;++i) scanf("%s",mp[i]+1);
for(int i=1;i<=8;++i)
for(int j=1;j<=8;++j)
tu[i][j] = (mp[i][j]=='#');
cout << dfs(1,1,8,8);
fclose(stdin);fclose(stdout);
return 0;
}
/*
##..####
#####..#
..#.#...
#..##.##
.#.###.#
####.###
#.#...#.
##....#.
168
*/

  

【csp模拟赛4】基站建设 (station.cpp)的更多相关文章

  1. Problem 3 基站建设 (station.cpp)———2019.10.6

    在此郑重的感激wxyww大佬 wxyww tql [题目描述]小 Z 的爸爸是一位通信工程师,他所在的通信公司最近接到了一个新的通信工程建设任务,他们需要在 C 城建设一批新的基站.C 城的城市规划做 ...

  2. CSP模拟赛游记

    时间:2019.10.5 考试时间:100分钟(连正式考试时间的一半还没有到)题目:由于某些原因不能公开. 由于第一次接触NOIinux系统所以连怎么建文件夹,调字体,如何编译都不知道,考试的前半小时 ...

  3. 【csp模拟赛4】 珠江夜游 (cruise.cpp)-二分,贪心

    Problem 1 珠江夜游 (cruise.cpp) [题目描述] 小 Z 放假后难得来一趟广州游玩,当然要吃遍广州各路美食小吃然后再 到珠江新城看看远近闻名的小蛮腰啦!可当小 Z 一路吃吃吃以后, ...

  4. 【csp模拟赛1】铁路网络 (network.cpp)

    [题目描述] 在暑假来临之际,小 Z 的地理老师布置了一个暑假作业,让同学们暑假期间 了解一下 C 国的铁路发展史.小 Z 在多番查证资料后发现,C 国在铁路发展初期, 铁路网络有着一个严密规整的结构 ...

  5. 【csp模拟赛5】限制 (restrict.cpp)--数学

    自己看吧: 爆搜代码: //春水初涨-春林初盛-春风十里-不如你 //----hzwer // 这是啥子题,读不懂-- //题意有问题 -- #include<iostream> #inc ...

  6. 【csp模拟赛5】购物(shopping.cpp)--常规

    多项式,因为每次的x相同,所以把a和b相加就行了,然后找对称轴,找离对称轴最近的整数点,然而我却写了个暴力,没看x #include <iostream> #include <cst ...

  7. 【csp模拟赛4】旅行计划 (travelling.cpp)--欧拉回路

    [题目描述] 小 Z 打算趁着暑假,开启他的旅行计划.但与其他同学不同的是,小 Z 旅 行时并不关心到达了哪个网红景点打了哪些卡.小 Z 更关注沿路的风光,而且 小 Z 觉得,尽管多次到达同一个地方, ...

  8. 【csp模拟赛1】不服来战 (challenge.cpp)

    [题目描述] 最近小 Z 和他的朋友都迷上了一款手机游戏:不服来战. 游戏的设定十分简单,在游戏开始时,会给出一排共 N 个灯,有的灯是开着 的有的是关着的,每个灯都有一个分数.而玩家可以进行任意次操 ...

  9. 1003 NOIP 模拟赛Day2 城市建设

    题面不好找放一个吧. Description 描述 在有$N$个地级市的H省,政府为了城市开发建设,决定先修路,后造房子,以吸引外来人员.一开始每个城市中有$b_i$个住户,而在两个城市$u,v$之间 ...

随机推荐

  1. 【题解】Luogu P5279 [ZJOI2019]麻将

    原题传送门 希望这题不会让你对麻将的热爱消失殆尽 我们珂以统计每种牌出现的次数,不需要统计是第几张牌 判一副牌能不能和,类似这道题 对于这题: 设\(f[i][j][k][0/1]\)表示前\(i\) ...

  2. jupyter notebook在 mac 使用

    1. 查看当前 conda 所拥有的环境列表 conda env list 2. 选择要进入的环境 source activate your_env_name 3. 启动 jupyter jupyte ...

  3. Quartz时间配置(周期任务)

     序号 说明  是否必填  允许填写的值 允许的通配符  1  秒  是  0-59    , - * /  2  分  是  0-59   , - * /  3 小时  是  0-23   , - ...

  4. MyCat - 数据库中间插件

    什么是MyCat 是目前最流行的分布式数据库中间插件 为什么使用MyCat 如今随着互联网的发展,数据的量级也是撑指数的增长,从GB到TB到PB.对数据的各种操作也是愈加的困难,传统的关系性数据库已经 ...

  5. 浅谈JS中 var let const 变量声明

    浅谈JS中 var let const 变量声明 用var来声明变量会出现的问题: 1. 允许重复的变量声明:导致数据被覆盖 2. 变量提升:怪异的数据访问.闭包问题 3. 全局变量挂载到全局对象:全 ...

  6. Java 之 ServletContext 对象

    ServletContext 对象 一.概念 ServletContext对象:代表整个 web 应用,可以和程序的容器(服务器)来通信. 二.获取 1.通过request 获取 方法: reques ...

  7. Android Scroller详解

    在学习使用Scroller之前,需要明白scrollTo().scrollBy()方法. 一.View的scrollTo().scrollBy() scrollTo.scrollBy方法是View中的 ...

  8. 140款Android开源优秀项目源码

    BeautifulRefreshLayout-漂亮的美食下拉刷新 https://github.com/android-cjj/BeautifulRefreshLayout/tree/Beautifu ...

  9. 【WPF】EntityframeworkCore Update注意事项

    The instance of entity type 'Book' cannot be tracked because another instance with the same key valu ...

  10. Java开发环境之Eclipse

    查看更多Java开发环境配置,请点击<Java开发环境配置大全> 拾壹章:Eclipse安装教程 1)去官网下载安装包 http://www.eclipse.org/downloads/ ...