平面上有 n 个点,如何求出任意两点的曼哈顿距离的最大值?

曼哈顿距离的公式为:

\[d((x_1, y_1), (x_2, y_2)) = |x_1 - x_2| + |y_1 - y_2|
\]

为了最大化曼哈顿距离,可以考虑绝对值展开的所有情况,我们可以考虑以下四个表达式:

对于点 $ (x_i, y_i) ) 和 ( (x_j, y_j) $,曼哈顿距离 $ |x_i - x_j| + |y_i - y_j| $ 可以转化为以下四种形式之一:

  1. $ (x_i + y_i) - (x_j + y_j) $
  2. $ (x_i - y_i) - (x_j - y_j) $
  3. $ -(x_i + y_i) + (x_j + y_j) $
  4. $ -(x_i - y_i) + (x_j - y_j) $

那么我们只需要跟踪这两个表达式的最大值和最小值:

  1. $ f_1(x, y) = x + y $
  2. $ f_2(x, y) = x - y $

对于每个表达式,我们可以找到其最大值和最小值,然后计算这些最大值和最小值之间的差值。

  1. 初始化四组变量,用来记录上述四个表达式的最大值和最小值:

    • $ \text{max1} = \text{min1} = x_1 + y_1 $
    • $ \text{max2} = \text{min2} = x_1 - y_1 $
  2. 遍历所有点 \((x_i, y_i)\),更新这四个值

  3. 计算两组差值的最大值:

    • $ d1 = \text{max1} - \text{min1} $
    • $ d2 = \text{max2} - \text{min2} $

    两个值实际上代表了所有四种绝对值展开的情况,几何上即线段从左下到右上和从左上到右下的两种情况。

  4. 曼哈顿距离的最大值就是最大值:

    \[\text{max_distance} = \max(d1, d2)
    \]

这个算法的时间复杂度为 $ O(n) $,因为只需遍历所有点一次即可完成所有更新和计算。

int maxManhattanDistance(const vector<pair<int, int>>& points) {
int max1 = INT_MIN/2, min1 = INT_MAX/2;
int max2 = INT_MIN/2, min2 = INT_MAX/2; for (const auto& point : points) {
int x = point.first;
int y = point.second; // 更新 max1 和 min1
int f1 = x + y;
max1 = max(max1, f1);
min1 = min(min1, f1); // 更新 max2 和 min2
int f2 = x - y;
max2 = max(max2, f2);
min2 = min(min2, f2);
} int d1 = max1 - min1;
int d2 = max2 - min2; return max(d1, d2);
} int main() {
// 示例输入
vector<pair<int, int>> points = {{1, 2}, {3, 4}, {6, 1}, {-1, -3}}; int maxDistance = maxManhattanDistance(points);
cout << "Maximum Manhattan Distance: " << maxDistance << endl; return 0;
}

高效求解 n 个点之间的最大曼哈顿距离的更多相关文章

  1. Python编程学习,高效求解素数程序实例

    素数是编程中经常需要用到的. 作为学习Python的示例,下面是一个高效求解一个范围内的素数的程序,不需要使用除法或者求模运算. #coding:utf-8 #设置python文件的编码为utf-8, ...

  2. 获取经纬度之间两点间真实距离(适用于GoogleMap,BaiduMap,Amap等)

    如何获取经纬度之间两点间真实距离(适用于GoogleMap,BaiduMap,Amap等)  目标:使用百度定位sdk开发实时移动距离计算功能,根据经纬度的定位,计算行驶公里数并实时刷新界面显示.大家 ...

  3. poj 2187 Beauty Contest(凸包求解多节点的之间的最大距离)

    /* poj 2187 Beauty Contest 凸包:寻找每两点之间距离的最大值 这个最大值一定是在凸包的边缘上的! 求凸包的算法: Andrew算法! */ #include<iostr ...

  4. 在k-means或kNN,我们是用欧氏距离来计算最近的邻居之间的距离。为什么不用曼哈顿距离?

    曼哈顿距离只计算水平或垂直距离,有维度的限制.另一方面,欧氏距离可用于任何空间的距离计算问题. 因为,数据点可以存在于任何空间,欧氏距离是更可行的选择.例如:想象一下国际象棋棋盘,象或车所 做的移动是 ...

  5. poj 1985 Cow Marathon 树的直径

    题目链接:http://poj.org/problem?id=1985 After hearing about the epidemic of obesity in the USA, Farmer J ...

  6. 2021.07.09 K-D树

    2021.07.09 K-D树 前置知识 1.二叉搜索树 2.总是很长的替罪羊树 K-D树 建树 K-D树具有二叉搜索树的形态,对于每一个分类标准,小于标准的节点在父节点左边,大于标准的节点在父节点右 ...

  7. 欧几里德&扩展以及求解线性方程学习总结--附上poj1061解题报告

    欧几里德算法: 欧几里德就是辗转相除法,调用这个gcd(a,b)这个函数求解a,b的最大公约数 公式: gcd(a,b)=gcd(b,a%b):并且gcd(a,b)=gcd(b,a)=gcd(-a,b ...

  8. python爬虫 | 一条高效的学习路径

    数据是创造和决策的原材料,高质量的数据都价值不菲.而利用爬虫,我们可以获取大量的价值数据,经分析可以发挥巨大的价值,比如: 豆瓣.知乎:爬取优质答案,筛选出各话题下热门内容,探索用户的舆论导向. 淘宝 ...

  9. Edit Distance问题在两种编程范式下的求解

    本文已授权 [Coding博客](https://blog.coding.net) 转载 前言 Edit Distance,中文叫做编辑距离,在文本处理等领域是一个重要的问题,以下是摘自于百度百科的定 ...

  10. 概率分布之间的距离度量以及python实现

    1. 欧氏距离(Euclidean Distance)       欧氏距离是最易于理解的一种距离计算方法,源自欧氏空间中两点间的距离公式.(1)二维平面上两点a(x1,y1)与b(x2,y2)间的欧 ...

随机推荐

  1. 树莓派3b+ 安装windows10 arm版本的方法及使用体验

    首先,我再网上找到了一个很详细的为树莓派3b安装windows10 arm的教程,实际操作下来发现并不可行. 最后找到了可行的教程: 第3章 将Windows10镜像写入TF卡:https://zhu ...

  2. 用一杯星巴克的钱,训练自己私有化的ChatGPT

    文章摘要:用一杯星巴克的钱,自己动手2小时的时间,就可以拥有自己训练的开源大模型,并可以根据不同的训练数据方向加强各种不同的技能,医疗.编程.炒股.恋爱,让你的大模型更"懂"你-. ...

  3. 前端黑科技:使用 JavaScript 实现网页扫码功能

    在数字化时代,二维码已经渗透到我们生活的方方面面.从移动支付到产品溯源,二维码凭借其便捷性和高效性,成为了信息传递的重要载体.而随着前端技术的不断发展,我们甚至可以使用 JavaScript 在网页端 ...

  4. FFmpeg开发笔记(四十六)利用SRT协议构建手机APP的直播Demo

    ​不管是传统互联网还是移动互联网,实时数据传输都是刚需,比如以QQ.微信为代表的即时通信工具,能够实时传输文本和图片.其中一对一的图文通信叫做私聊,多对多的图文通信叫做群聊. 除了常见的图文即时通信, ...

  5. springcloud集成grpc(一)

    码云地址:https://gitee.com/lpxs/lp-springcloud.git 有问题可以多沟通:136358344@qq.com. GRPC简介 是谷歌开源的一个高性能的.通用的RPC ...

  6. div构建table

    1.Css display值与解释-(详细可见CSS手册的CSS display手册)参数:block :块对象的默认值.用该值为对象之后添加新行none :隐藏对象.与visibility属性的hi ...

  7. 从0实现基于Linux socket聊天室-实现聊天室的公聊、私聊功能-4

    前面文章链接如下: <从0实现基于Linux socket聊天室-多线程服务器模型-1> <从0实现基于Linux socket聊天室-多线程服务器一个很隐晦的错误-2> &l ...

  8. 修改ListCtrl控件列标题文本居左显示

    修改ListCtrl控件标题文本居左显示 原来的列标题文本是居中显示: 现在要把列表文本居中改为居左显示 其方法如下: 获得标题控件句柄 g_listCtrl.m_hWnd为ListCtrl控件的句柄 ...

  9. 关于封装axios报错Cyclic dependency的问题

    在npm start的时候直接报错Cyclic dependency循环依赖 JS 循环依赖 (require cycle)_腾飞日记-CSDN博客_js循环依赖 可以看上面的博文了解一下这个错大概在 ...

  10. jpa 查询 报错 EntityNotFoundException

    背景: 使用JPA查询,串接到另外一张表时,由于没有实际在表格关系中指定外键,而是在实体类中指定外键 导致关联表中的数据被删除时,JPA查询时,报错EntityNotFoundException 方案 ...