算法分析与设计第五次作业

  1. 问题
    最近对问题要求在包含有n个点的集合S中,找出距离最近的两个点。设 p1(x1,y1),p2(x2,y2),……,pn(xn,yn)是平面的n个点)

  2. 解析
    该题目可以采用暴力法与分治法,分治法如下:
    在利用分治法思想解决此问题时,首先考虑将最近对问题进行分治,设计其分治策略。将集合S分成两个子集S1和S2,根据
    平衡子问题原则,每个子集中的点数大致都为n/2。这样分治后,最近点对将会出现三种情况:在S1中,在S2中或者最近
    点对分别在集合S1和S2中。利用递归分析法分别计算前两种情况,第三种方法另外分析。求解出三类子情况后,
    再合并三类情况,比较分析后输出三者中最小的距离。

  3. 设计
    步骤1:根据点的y值和x值对S中的点排序。
    步骤2:找出中线L将S划分为SL和SR
    步骤3:将步骤2递归的应用解决SL和SR的最近点对问题,并令d=min(dL,dR)。
    步骤4:将L-dL+d内的点以y值排序,对于每一个点(x1,y1)找出y值在y1-dy1+d内的所有点,计算距 离为d’,如果d’小于d,令d=d’,最后的d值就是答案。

  4. 分析
    时间复杂度为O【n】

  5. 源码
    https://github.com/FPhoenixtree/-/blob/main/%E7%AC%AC%E4%BA%94%E6%AC%A1%E4%BD%9C%E4%B8%9A%E6%97%B6%E9%97%B4%E7%82%B9%E5%AF%B9%E9%97%AE%E9%A2%98%E5%88%86%E6%B2%BB%E6%B3%95.cpp

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值