在此郑重的感激wxyww大佬

wxyww tql

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

【输入格式】
输入一个 8 行 8 列的矩阵,全部由“#”和“.”组成。
【输出格式】
输出一个整数,表示花费的最少时间。
【样例输入一】
........
........
...#....
.#......
.......#
........
........
........
【样例输出一】
8
【样例输入二】
##..####
#####..#
..#.#...
#..##.##
.#.###.#
####.###
#.#...#.
##....#.
【样例输出二】
168
【数据范围】
设需要建设基站的街区数(即“#”的个数)为 n。

对于 30%的数据,n≤10;
对于 60%的数据,n≤20;
对于 100%的数据,n≤64。

记忆化搜索诶,,,

代码

 #include<cstdio>
#include<iostream>
#include<algorithm>
#include<cmath>
#include<cstring>
using namespace std;
char mp[][];
int f[][][][],tu[][];
int dfs(int x1,int y1,int x2,int y2);
int suan(int x1,int y1,int x2,int y2,int i1,int j1,int i2,int j2);
int jdz(int x) {
return x>?x:-x;
}
int main() {
freopen("station.in","r",stdin);
freopen("station.out","w",stdout);
memset(f,-,sizeof f);
for(int i=; i<=; i++)
for(int j=; j<=; j++)
cin>>mp[i][j];
for(int i=; i<=; ++i)
for(int j=; j<=; ++j)
tu[i][j] = (mp[i][j]=='#');
/*for(int i=1;i<=8;i++)
{
for(int j=1;j<=8;j++)
cout<<tu[i][j]<<" ";
cout<<"\n";
}*/
int ans=dfs(,,,);
cout<<ans;
fclose stdin;
fclose stdout;
return ;
}
int suan(int x1,int y1,int x2,int y2,int i1,int j1,int i2,int j2) {
int sum=;
for(int i=i1; i<=i2; i++)
for(int j=j1; j<=j2; j++)
sum+=(tu[i][j])*max(max(jdz(i-x1),jdz(i-x2)),max(jdz(j-y1),jdz(j-y2)));
return sum;
}
int dfs(int x1,int y1,int x2,int y2) {
if(x1>x2||y1>y2)return ;
if(f[x1][y1][x2][y2]!=-) 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+,y1,x2,y2);
res=min(res,suan(x1,y1,x2,y2,x2,y1,x2,y2)+dfs(x1,y1,x2-,y2));
res=min(res,suan(x1,y1,x2,y2,x1,y1,x2,y1)+dfs(x1,y1+,x2,y2));
res=min(res,suan(x1,y1,x2,y2,x1,y2,x2,y2)+dfs(x1,y1,x2,y2-));
return res;
}

Problem 3 基站建设 (station.cpp)———2019.10.6的更多相关文章

  1. Problem 1 珠江夜游 (cruise .cpp)———2019.10.6

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

  2. Problem 2 旅行计划 (travelling .cpp)———2019.10.6

    lth tql,lzpclxf tql Orz Problem 2 旅行计划 (travelling.cpp)[题目描述]小 Z 打算趁着暑假,开启他的旅行计划.但与其他同学不同的是,小 Z 旅行时并 ...

  3. 【csp模拟赛4】基站建设 (station.cpp)

    [题目描述] 小 Z 的爸爸是一位通信工程师,他所在的通信公司最近接到了一个新的通 信工程建设任务,他们需要在 C 城建设一批新的基站. C 城的城市规划做得非常好,整个城市被规整地划分为 8 行 8 ...

  4. 【转帖】5G基站建设下的“中国速度”:北上广深领跑全国,均超1万个

    5G基站建设下的“中国速度”:北上广深领跑全国,均超1万个 https://www.laoyaoba.com/html/news/newsdetail?source=pc&news_id=73 ...

  5. Problem B. Market(market.c/cpp/pas)

    Problem B. Market(market.c/cpp/pas)Time limit: 1 secondsMemory limit: 128 megabytes在比特镇一共有 n 家商店,编号依 ...

  6. 模拟赛 Problem 2 不等数列(num.cpp/c/pas)

    Problem 2 不等数列(num.cpp/c/pas) [题目描述] 将1到n任意排列,然后在排列的每两个数之间根据他们的大小关系插入“>”和“<”.问在所有排列中,有多少个排列恰好有 ...

  7. 模拟赛 Problem 1 高级打字机(type.cpp/c/pas)

    Problem 1 高级打字机(type.cpp/c/pas) [题目描述] 早苗入手了最新的高级打字机.最新款自然有着与以往不同的功能,那就是它具备撤销功能,厉害吧. 请为这种高级打字机设计一个程序 ...

  8. 2019.10 搜索引擎最新排名,Elasticsearch遥遥领先

    大数据的搜索平台已经成为了众多企业的标配,Elasticsearch.Splunk(商业上市公司).Solr(Apache开源项目)是其中最为优秀和流行的选择.在2019.10 最新搜索引擎排名中,E ...

  9. 【2019.10.17】十天Web前端程序员体验(软件工程实践第五次作业)

    结对信息.具体分工 Github地址:https://github.com/MokouTyan/131700101-031702425 学号 昵称 主要负责内容 博客地址 131700101 莫多 代 ...

随机推荐

  1. 近3年常考的Spring面试题及答案

    1. 一般问题 1.1. 不同版本的 Spring Framework 有哪些主要功能? Version Feature Spring 2.5 发布于 2007 年.这是第一个支持注解的版本. Spr ...

  2. 运行带有Activiti modeler时,出现这样的报错: java.rmi.AccessException: Cannot modify this registry

    最近在做整合Activiti Modeler工作流在线设计器的工作,运行IDEA时,出现了这样一个错误信息: 原因及解决办法:   Activiti默认打开了jmx功能,默认端口为1099,idea中 ...

  3. 我的第一个netcore2.2 api项目搭建(三)

    上一章快速添加了swagger文档管理功能,我的第一个netcore2.2 api项目搭建(二) 这一章实现目标三:api添加身份验证功能 在实现该目标之前,先得理解netcore运行机制. 这是微软 ...

  4. 【8】学习C++之this指针

    在学习类的时候,我们可以考虑到一种情况: class Array { public: Array(int len); ~Array(); void setLen(int len) { len=len; ...

  5. Vue安装及项目介绍

    目录 创建Vue项目 环境安装 创建项目 pycharm打开Vue项目 项目目录介绍 入口文件(main.js) 路由配置(router.js ) 组件 前台路由的基本工作流程 目录结构 根组件(Ap ...

  6. 记录下hbuilder vue项目打包APP 在IOS上点击延迟的问题

    做的项目打包成APP在IOS 上有延迟问题,在安卓下却不会,联想到之前 用IONIC时打包的APP也是 在IOS下有300毫秒延迟问题.所以 只能 认吧. 安装fastclick 插件: npm in ...

  7. Java 使用properties配置文件加载配置

    一般我们不把数据库的配置信息写死在代码中. 写好代码后,编译.调试,成功后只把输出目录中的东西(jar包..class文件.资源文件等)拷贝到服务器上,由运维来管理.服务器上是没有源文件的(.java ...

  8. 对List集合中的元素进行排序

    原文:http://blog.csdn.net/veryisjava/article/details/51675036 Collections对List集合中的数据进行排序 有时候需要对集合中的元素按 ...

  9. ApplicationContext的名称解释

    如果说BeanFactory是Spring的心脏,那么Application就是完整的身躯.ApplicationContext就是由BeanFactory派生出来的. 1.ApplicationCo ...

  10. php与阿里云短信接口接入

    使用阿里云短信API,需要在控制台获取以下必要参数,其中需要自己手机验证+官方审核多次,尤其审核需要保持耐心. 1. accessKeyId  相当于你的个人账户密钥: 2. accessKeySec ...