题解/算法 {E - Jump Distance Sum}

题解/算法 {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维度, 他可以每个维度完全独立 最终累加到一起即可;

正解是模板算法 给定若干点 求任意两点的切比距离之和;

  • 4
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值