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

【题目描述】

小 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
*/

  

原文地址:https://www.cnblogs.com/yelir/p/11560001.html

时间: 2024-10-31 18:13:46

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

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

Problem 1 珠江夜游 (cruise.cpp) [题目描述] 小 Z 放假后难得来一趟广州游玩,当然要吃遍广州各路美食小吃然后再 到珠江新城看看远近闻名的小蛮腰啦!可当小 Z 一路吃吃吃以后,天渐渐黑了, 珠江边上的建筑全亮起了灯,好看得不要不要的,于是小 Z 决定搭乘游艇从西 边的广州港沿着珠江夜游到小蛮腰脚下.小 Z 的游艇一路向东,可小 Z 却感觉 船动得出奇的慢,一问船家才知道,原来今天珠江上堵船了. 我们可以把供游艇航行的航道看作一条单行道,航道上 N+1 艘游艇自西 向东依次

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

[题目描述] 最近小 Z 和他的朋友都迷上了一款手机游戏:不服来战. 游戏的设定十分简单,在游戏开始时,会给出一排共 N 个灯,有的灯是开着 的有的是关着的,每个灯都有一个分数.而玩家可以进行任意次操作,每次操作 改变连续 K 盏灯的开关状态.尽管机智如小 Z 也总是没法得到最高分,没法把他 的朋友 PK 下来.于是他来向你请教,希望知道在不同情况下,最高分分别是多 少. [输入格式] 第一行,一个正整数 T,表示测试数据组数. 对于每组测试数据: 首先是一行两个正整数 N,K,意义如题目所述.

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

[题目描述] 小 Z 打算趁着暑假,开启他的旅行计划.但与其他同学不同的是,小 Z 旅 行时并不关心到达了哪个网红景点打了哪些卡.小 Z 更关注沿路的风光,而且 小 Z 觉得,尽管多次到达同一个地方,但如果来时的路不一样,也是别有一番 风味. 小 Z 事先准备了一份地图,地图上给出了 N 个小 Z 心仪的城市,依次编号 1…N,以及 M 条连接两个城市的路,编号 1…M.小 Z 打算把 M 条路都走一遍且 仅一遍,但他发现这样的路线可能是不存在的.于是他打算,当他走到一个城 市后发现从这个城市出

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

自己看吧: 爆搜代码: //春水初涨-春林初盛-春风十里-不如你 //----hzwer // 这是啥子题,读不懂-- //题意有问题 -- #include<iostream> #include<cstdlib> #include<algorithm> #include<cstdio> #include<map> #define mod 998244353 #define N 100000 using namespace std; int n,

【CSP模拟赛】Freda的迷宫(桥)

题目描述 Freda是一个迷宫爱好者,她利用业余时间建造了许多迷宫.每个迷宫都是由若干房间和走廊构成的,每条走廊都连接着两个不同的房间,两个房间之间最多只有一条走廊直接相连,走廊都是双向通过.  黄昏时候,Freda喜欢在迷宫当中漫步.每天,Resodo都会为Freda设计一个挑战方案.Resodo会指定起点和终点,请Freda来找到一条从起点到终点的简单路径.一条简单路径定义为一个房间序列,每个房间至多在序列里出现一次,且序列中相邻的两个房间有走廊相连.当起点和终点之间存在且仅存在一条简单路径

【csp模拟赛5】加减法--宽搜维护联通快

题目大意: 一开始想用并查集,发现很难维护联通块的代表元素,所以用了宽搜,开数组会炸,所以开一个优先队列维护,每扫完一个联通块,统计答案,清空优先队列,!!千万记住注意数组的大小!!! 代码: #include<cstdio> #include<iostream> #include<cstdlib> #include<algorithm> #include<cstring> #include<queue> #define int lo

【csp模拟赛3】flowers.cpp--循环节

题目描述 小 Q 最终还是过了独木桥. 前方的地上散落着 B 朵樱花,此时刮起了风,便引来一场樱花雨. 樱花雨一共持续了 N 秒.每一秒都会有 A 朵樱花飘落.小 Q 细心的记录了每一秒时间 后地上樱花的数目,并将其转换成了二进制.小 Q 想请你统计一下这些二进制数一共有多 少个 1. 输入 第一行一个 T 为数据组数.接下来 T 行,每行有 A.B.N,含义如题目所述. 输出 输出 T 行,每行一个整数为对应的答案. 样例输入 2 7 4 1 5 8 2 样例输出 3 5 样例说明 对于第一组

【CSP模拟赛】方程(数学)

题目描述 求关于x的方程:x1+x2+……xk=n的非负整数解的个数. 输入格式 仅一行,包含两个正整数n,k. 输出格式 一个整数,表示方程不同解的个数,这个数可能很大,你只需输出mod 20080814 的结果. 输入样例 1 1 输出样例 1提示数据范围对于50%的数据,n,k<=300对于80%的数据,n,k<=1000对于100%的数据,n,k<=100000 分析 第一眼看这不是结论题吗?直接就是C(n+k-1,n-1). 然后一看模数是个偶数,瞬间懵逼 最后直接赌命暴力分解

【CSP模拟赛】益智游戏(最短路&amp;拓扑排序)

题目描述 小P和小R在玩一款益智游戏.游戏在一个正权有向图上进行. 小P 控制的角色要从A 点走最短路到B 点,小R 控制的角色要从C 点走最短路到D 点. 一个玩家每回合可以有两种选择,移动到一个相邻节点或者休息一回合. 假如在某一时刻,小P 和小R 在相同的节点上,那么可以得到一次特殊奖励,但是在每 个节点上最多只能得到一次. 求最多能获得多少次特殊奖励 输入格式 第一行两个整数n,m 表示有向图的点数和边数. 接下来m 行每行三个整数xi,yi,li,表示从xi 到yi 有一条长度为li