题目大意

$R \times C$ 的网格,格子间的距离取曼哈顿距离。有些格子是邮局。现在可以把至多一个不是邮局的格子变成邮局,问每个格子到最近的邮局的曼哈顿距离的最大值最小是多少。

数据范围

  • $ 1 \le R \le 250 $
  • $ 1 \le C \le 250 $
  • 100 组测试数据
  • Time limit: 15 s

分析

显然可以二分答案。

几何视角

考虑平面上的整点(也称格点)。到一个格点的曼哈顿距离不大于 $k$ 的所有格点的轮廓是一个旋转了 45° 的正方形( For any point, the set of points within a manhattan distance of K form a square rotated by 45 degrees.),或者叫菱形。

考虑所有离现有邮局的最短距离大于 $k$ 的格点,简称「未覆盖点」,每个未覆盖点都关联着一个上一段所说的菱形。如果所有菱形的交集不为空,那么只要从交集中取一点作为新邮局即可。

这个方法的困难在于两个菱形的交集并不好计算。不过我们可以通过坐标变换,把原本的菱形变成正方形。正方形的交集是容易计算的。
这个变换在算法竞赛界称为曼哈顿距离转切比雪夫距离。

平面上两点 $ (x_1, y_1) $,$ (x_2, y_2) $ 的契比雪夫距离定义为 $\max(|x_1 - x_2|, |y_1 - y_2|)$ 。

对应的坐标变换是 $(x, y) \longrightarrow (x + y, x - y)$ 。

代数视角

上述坐标变换的根源是曼哈顿距离的定义:

两点 $ (x_1, y_1) $,$ (x_2, y_2) $ 的曼哈顿距离无非是下述四个值中最大者

$ (x_1 - x_2) + (y_1 - y_2) $
$ (x_1 - x_2) + (y_2 - y_1) $
$ (x_2 - x_1) + (y_1 - y_2) $
$ (x_2 - x_1) + (y_2 - y_1) $
亦即
$(x_1 + y_1) - (x_2 + y_2)$
$(x_1 - y_1) - (x_2 - y_2) $
$(x_2 - y_2) - (x_1 - y_1) $
$(x_2 + y_2) - (x_1 + y_1)$
四者的最大值。

于是有
\begin{equation}
|x_1 - y_1 | + |y_1 - y_2| = \max(|(x_1 + y_1) - (x_2 + y_2)|, |(x_1 - y_1) - (x_2 - y_2)|) \label{E:1}
\end{equation}

利用 \eqref{E:1} 式,我们可以从代数视角(而非几何视角)来解决这个问题。

不妨把新邮局的坐标视作 $(x_2, y_2)$,把现有邮局尚不能覆盖的点的坐标视作 $(x_1, y_1)$ 。

问题转化为
是否存在点 $(x_2, y_2)$,满足当 $(x_1, y_1)$ 取遍未覆盖点,\eqref{E:1} 的值始终不超过 $k$,换言之 \eqref{E:1} 的最大值不超过 $k$ 。

注意到,当 \eqref{E:1} 取最大值时,$x_1 + y_1$,$x_1 - y_1$ 必取最值(即取最大值或最小值)。

因此我们可以先遍历未覆盖点 $(x_1, y_1)$,算出 $x_1 + y_1$,$x_1 - y_1$ 的最值,再枚举所有可能的新邮局 $(x_2, y_2)$,求 \eqref{E:1} 式的最大值,进行判断。

最新文章

  1. 【JavaWeb】SSM+SpringSecurity+EhCache+JCaptcha 完整Web基础框架(六)
  2. python 安装模块步骤
  3. Linq to sql-存储过程
  4. IT公司100题-10-翻转句子中单词的顺序
  5. [开发]Win7环境下Eclipse连接Hadoop2.2.0
  6. 工作中常用的QTP操作Excel函数
  7. 打包程序时的证书问题(上传APP就出现Missing iOS Distribution signing indetity for)
  8. 《Effective C#》读书笔记-1.C# 语言习惯-2.使用运行时常量(readonly)而不是编译时常量(const)
  9. ES6 正则的扩展
  10. C#学习笔记-建造者模式
  11. 【学习】Linux Shell脚本编程
  12. 使用LVM进行分区扩展的记录
  13. python numpy 科学计算通用函数汇总
  14. C# 控件之数据绑定
  15. js-其他跨域技术(JSONP`Comet)
  16. 【hdu 5628】Clarke and math (Dirichlet卷积)
  17. Linux查看所有用户和组信息
  18. SV coverage
  19. Javascropt-KeyCode
  20. BeanDefinition到Bean

热门文章

  1. 【转】vue 手动挂载$mount() 获取 $el
  2. MessagePack Java 0.6.X 多种类型变量的序列化和反序列化(serialization/deserialization)
  3. EasySwoole 在mac上装虚拟机centos共享mac目录报错处理
  4. 关于SpringBoot跨域的问题
  5. highcharts柱状图、饼状图
  6. JVM 监控工具——jconsole
  7. ReentrantLock源码探究1:非公平锁的获取和释放
  8. 转载:一文详解SQL解析与应用
  9. 解决SpringCloud使用Feign跨服调用时header请求头中的信息丢失
  10. Spring学习之==>入门知识