【题目描述】

小 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. CentOS7 搭建 NFS 服务器

    环境: 系统版本:CentOS 7.5 一.服务端配置 1.配置环境 关闭防火墙服务 # 停止并禁用防火墙 $ systemctl stop firewalld $ systemctl disable ...

  2. 对于Node中Express框架的中间件概念的感知

    中间件是什么呢? 中间件就是客户端http请求发起传送到服务器和服务器返回响应之间的一些处理函数. 为什么要使用中间件? 通过中间件,可以对数据进行操作使得我们能方便地操作请求数据编写服务器响应.如b ...

  3. 《JAVA高并发编程详解》-wait和sleep

  4. (转) Python3—UnicodeEncodeError 'ascii' codec can't encode characters in position 0-1

    (转)python(三):Python3-UnicodeEncodeError 'ascii' codec can't encode characters in position 0-1 python ...

  5. oracle之PLSQL导出-导入-表-存储过程等操作--亲测好用

    1.背景 实际开发中考虑到安全,不会将生产库的数据和本地开发数据进行同步操作,而是采用导入导出sql语句的方式操作; 例如在开发环境写好的存储过程要更新到生产环境,那么就需要使用导出和导入功能. 2. ...

  6. Linux DNS 主从复制

    设置主从DNS的主要是为了冗余,分担压力,防止服务器宕机后,DNS无法正常解析. 配置 master 正常配置DNS服务. 设置主机名 [root@localhost ~]# hostnamectl ...

  7. 详解shell脚本括号区别--$()、$「 」、$「 」 、$(()) 、「 」 、「[ 」]

    概述 很多时候我们在写shell脚本的时候总会碰到不同的括号,那么这些不同的括号有什么区别呢? $() 用于命令交换 说明:平时脚本用的``符号也是用于命令交换的哦,和$() 的操作是一样的 ${ } ...

  8. HTML&CSS基础-html标签的实体

    HTML&CSS基础-html标签的实体 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.HTML源代码 <!DOCTYPE html> <html&g ...

  9. 【转载】.Net 大型分布式基础服务架构横向演变概述

    原文:https://www.cnblogs.com/chejiangyi/p/5220217.html 一. 业务背景 构建具备高可用,高扩展性,高性能,能承载高并发,大流量的分布式电子商务平台,支 ...

  10. 【原创】selenium+python+openpyxl实现登录自动化测试,自动读取excel用例数据,并将数据结果自动写入到excel

    # -*- coding: utf-8 -*- from selenium import webdriver from openpyxl import load_workbook from time ...