算法导论求n个点的最小距离

该博客介绍了如何高效地求解n个点之间的最小距离问题。通过将点按横坐标排序,然后采用分治策略,将问题简化为计算左右半部分的最近点距离和跨越分割线的点对的最短距离。关键在于优化第三步,通过限制点与分割线的距离和纵坐标差,减少比较次数。最终实现算法的时间复杂度为O(n(logn)^2),并提出通过归并排序进一步优化到O(n)。文章还提及了一个具体的编程题目(HDU 1007 Quoit Design)的解决方案,并提供了已通过AC的代码。
摘要由CSDN通过智能技术生成

算法:

0:把所有的点按照横坐标排序
1:用一条竖直的线L将所有的点分成两等份
2:递归算出左半部分的最近两点距离d1,右半部分的最近两点距离d2,取d=min(d1,d2)
3:算出“一个在左半部分,另一个在右半部分”这样的点对的最短距离d3。
4:结果=min(d1,d2,d3)

关键就是这第3步。貌似这需要n^2的时间,把左边每个点和右边每个点都对比一下。其实不然。秘密就在这里。

首先,两边的点,与分割线L的距离超过d的,都可以扔掉了。
其次,即使两个点P1,P2(不妨令P1在左边,P2在右边)与分割线L的距离(水平距离)都小于d,如果它们的纵坐标之差大于d,也没戏。
就是这两点使得搜索范围大大减小:
对于左半部分的,与L的距离在d之内的,每个P1来说:右半部分内,符合以上两个条件的点P2最多只有4个!
原因就是:
d是两个半平面各自内,任意两点的最小距离,因此在同一个半平面内,任何两点距离都不可能超过d。
我们又要求P1和P2的水平距离不能超过d,垂直距离也不能超过d,在这个d*2d的小方块内,最多只能放下8个距离不小于d的点。

因此,第3步总的比较距离的次数不超过n*8。

第3步的具体做法是:

3.1 删除所有到L的

  • 4
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值