题解/算法 {E - Jump Distance Sum}
@LINK: https://atcoder.jp/contests/abc351/tasks/abc351_e
;
AB两点可达 <->
(A.x+A.y) 与 (B.x+B.y) 奇偶性一致
;
其距离等于 max( B.x-A.x, B.y-A.y)
;
如果你没看出来 这是切比雪夫距离, 这题还是挺难的…
看一个错误做法:
分成2组, 奇数和偶数, 比如对于x+y
全是偶数的点集合S;
1: 任意两点他俩的abs(A.x-B.x)
之和, 记作SX;
2: 任意两点他俩的abs(A.y-B.y)
之和, 记作SY;
可是, 比如对于(1,9) (3, 2)
, 你计算了abs(1-3) = 2
在SX, 也计算了abs(9-2) = 7
在SY, 可是2
其实是不起作用的; 要去掉他, 于是你想着如何去除他, 这就很难…
因为切比距离 他是max( X维度, Y维度),
他俩是捆绑在一起的 不能分开 , 跟曼哈顿距离不同 曼哈顿是X维度 + Y维度
, 他可以每个维度完全独立 最终累加到一起即可;
正解是模板算法 给定若干点 求任意两点的切比距离之和;