洛谷—— P2658 汽车拉力比赛
https://www.luogu.org/problem/show?pid=2658
题目描述
博艾市将要举行一场汽车拉力比赛。
赛场凹凸不平,所以被描述为M*N的网格来表示海拔高度(1≤ M,N ≤500),每个单元格的海拔范围在0到10^9之间。
其中一些单元格被定义为路标。组织者希望给整个路线指定一个难度系数D,这样参赛选手从任一路标到达别的路标所经过的路径上相邻单元格的海拔高度差不会大于D。也就是说这个难度系数D指的是保证所有路标相互可达的最小值。任一单元格和其东西南北四个方向上的单元格都是相邻的。
输入输出格式
输入格式:
第一行两个整数M和N。第2行到第M+1行,每行N个整数描述海拔高度。第2+M行到第1+2M
行,每行N个整数,每个数非0即1,1表示该单元格是一个路标。
输出格式:
一个整数,即赛道的难度系数D。
输入输出样例
3 5
20 21 18 99 5
19 22 20 16 26
18 17 40 60 80
1 0 0 0 1
0 0 0 0 0
0 0 0 0 1
21 二分一个最小差值,bfs验证是否可以遍历全部路标
#include <cstring>
#include <cstdlib>
#include <cstdio>
#include <queue> #define max(a,b) (a>b?a:b)
inline void read(int &x)
{
x=; register char ch=getchar();
for(; ch>''||ch<''; ) ch=getchar();
for(; ch>=''&&ch<=''; ch=getchar()) x=x*+ch-'';
}
const int N();
int n,m,h[N][N],cnt;
int go[N][N],sx,sy; bool vis[N][N];
int fx[]={,,,-};
int fy[]={,,-,};
struct Node {
int x,y;
int cnt;
}u,v;
int l,r,mid,ans;
inline bool check(int x)
{
int ret=;
std::queue<Node>que;
memset(vis,,sizeof(vis));
u.cnt=; u.x=sx; u.y=sy;
que.push(u); vis[sx][sy]=;
for(; !que.empty(); que.pop())
{
u=que.front();
if(ret==cnt) return ;
for(int i=; i<; ++i)
{
v.x=u.x+fx[i];
v.y=u.y+fy[i];
if(vis[v.x][v.y]||v.x>n||v.y>m||v.x<||v.y<) continue;
if(abs(h[u.x][u.y]-h[v.x][v.y])<=x)
{
que.push(v),vis[v.x][v.y]=;
if(go[v.x][v.y]) ret++;
}
}
}
return ;
} int Presist()
{
read(n),read(m);
for(int i=; i<=n; ++i)
for(int j=; j<=m; ++j)
read(h[i][j]),r=max(r,h[i][j]);
for(int x,i=; i<=n; ++i)
for(int j=; j<=m; ++j)
{
read(go[i][j]);
if(go[i][j])
{ cnt++;sx=i;sy=j; }
}
for(; l<=r; )
{
mid=l+r>>;
if(check(mid))
{
ans=mid;
r=mid-;
}
else l=mid+;
}
printf("%d\n",ans);
return ;
} int Aptal=Presist();
int main(int argc,char*argv[]){;}
洛谷—— P2658 汽车拉力比赛的更多相关文章
- 洛谷——P2658 汽车拉力比赛
		P2658 汽车拉力比赛 题目描述 博艾市将要举行一场汽车拉力比赛. 赛场凹凸不平,所以被描述为M*N的网格来表示海拔高度(1≤ M,N ≤500),每个单元格的海拔范围在0到10^9之间. 其中一些 ... 
- 洛谷 P2658 汽车拉力比赛
		题目传送门 解题思路: 二分答案,然后bfs验证,如果从一个路标可以达到其它所有路标,则答案可行.知道找到最佳答案. AC代码: #include<iostream> #include&l ... 
- P2658 汽车拉力比赛
		题目描述 博艾市将要举行一场汽车拉力比赛. 赛场凹凸不平,所以被描述为M*N的网格来表示海拔高度(1≤ M,N ≤500),每个单元格的海拔范围在0到10^9之间. 其中一些单元格被定义为路标.组织者 ... 
- scau 8616 汽车拉力比赛
		上次我们过了二分图的最佳匹配,现在我们看一道题目,经典的二分图的最佳匹配题目 8616 汽车拉力比赛 时间限制:500MS 内存限制:1000K提交次数:71 通过次数:24 题型: 编 ... 
- [洛谷P1707] 刷题比赛
		洛谷题目连接:刷题比赛 题目背景 nodgd是一个喜欢写程序的同学,前不久洛谷OJ横空出世,nodgd同学当然第一时间来到洛谷OJ刷题.于是发生了一系列有趣的事情,他就打算用这些事情来出题恶心大家-- ... 
- 洛谷P2831 愤怒的小鸟 + 篮球比赛1 2
		这三道题一起做,有一点心得吧. 愤怒的小鸟,一眼看上去是爆搜,但是实现起来有困难(我打了0分出来). 还有一种解法是状压DP. 抛物线一共只有那么多条,我们枚举抛物线(枚举两个点),这样就能够预处理出 ... 
- 洛谷 P4009 汽车加油行驶问题 解题报告
		P4009 汽车加油行驶问题 题目描述 给定一个\(N×N\)的方形网格,设其左上角为起点◎,坐标(1,1) ,\(X\)轴向右为正,\(Y\)轴向下为正,每个方格边长为1 ,如图所示. 一辆汽车从起 ... 
- 洛谷 U14472 数据结构【比赛】  【差分数组 + 前缀和】
		题目描述 蒟蒻Edt把这个问题交给了你 ---- 一个精通数据结构的大犇,由于是第一题,这个题没那么难.. edt 现在对于题目进行了如下的简化: 最开始的数组每个元素都是0 给出nnn,optopt ... 
- 洛谷P4009 汽车加油行驶问题
		题目描述 给定一个 N \times NN×N 的方形网格,设其左上角为起点◎,坐标(1,1)(1,1),XX 轴向右为正, YY 轴向下为正,每个方格边长为 11 ,如图所示. 一辆汽车从起点◎出发 ... 
随机推荐
- DHTML_____window对象的事件
			<html> <head> <meta charset="utf-8"> <title>window对象事件</title&g ... 
- CSS动画持续汇总中
			一:向上的动态箭头------------------http://www.5599.com/88lz/up_direct.html 
- oa系统部署
			1.配置java环境变量 新建:JAVA_HOME C:\Program Files\Java\jdk1.6.0_45 path添加 C:\Program Files\Java\jdk1.6.0_ ... 
- java死锁问题
			一.先从定义上了解一下死锁 二.从代码角度上去解释一下死锁问题 三.上述程序就是出现了死锁,我们来查看一下 1.命令如下 cmd>>jps(查看到了死锁线程所在的类,前面是PID) 2 ... 
- jsTree插件简介(三)
			UI-plugin JSTree的UI插件:用来处理选择.不选和鼠标悬浮树选项的插件. 一.属性包括: 1.select_limit:指定一次可以选中几个节点,默认为-1,表示无限制选中. 2.sel ... 
- Jmeter在windows上安装和环境配置
			一.Jmeter简单介绍 Apache JMeter是Apache组织开发的基于Java的压力测试工具.它可以用于测试静态和动态资源,例如静态文件.Java小服务程序.CGI 脚本.Java 对象.数 ... 
- Spring事物不回滚
			今天发现个自己的bug,仔细排查后,发现根本原因我在service方法中抛出的异常被控制层的方法捕获了,所以后台页面也只是出现个错误提示,而数据却没有回滚. 解决方式:对自己抛出的异常使用try ca ... 
- 11servlet接口
			11.servlet接口-2018/07/23 1.servlet 是一个接口,需要导包javax.servlet.Servlet; 第一种编写一个servlet程序的方法 写一个Java类,实现se ... 
- 字符串匹配「 KMP 算法 」
			引言 众所周知,字符串无论是在 OI 中还是别的计算机领域都占有比较大的比重,今天说的就是一个关于匹配字符串的算法——「 KMP 算法 」. 0x00 KMP 算法用于解决这样的一类问题:给定一个文本 ... 
- Python3.0科学计算学习之类
			类: Python中的类是一个抽象的概念,甚至比函数还要抽象.可以把它简单的看作是数据以及由存取.操作这些数据的方法所组成的一个集合.类是Python的核心概念,是面向对象编程的基础. 类有如下的优点 ... 
