zoukankan      html  css  js  c++  java
  • 计算几何学习8

    由于poj炸了 而题单上有很多poj的题

    就先开始第二部分了

    学习了两个固定算法

    最小圆覆盖和平面上最近点对

    平面上最近点对采用的是分治的思想

    把一个x有序的序列分成A,B左右两部分

    当得到A内最近点对距离,B类最近点对距离后

    先更新大序列的答案ans

    A,B间最近点对的产生 显然在x坐标距离mid点不超过ans的区间内产生

    我们把这段区间拿出来,对y排序

    再逐对更新

    值得注意的地方

    1)为了确保速度 可以在第二次对y排序的时候采取对标号排序的方式

    2)在枚举点对更新的时候注意在y差值 >= ans时跳出

    3)递归终止条件可以是一个两个或者两个三个 第二种可能比较好写?

    这种算法复杂度大概是nlogn的

    ZOJ 2107板子题

    POJ 3714 给不同的点标号 仅在标号不同时更新答案就行了

    最小圆覆盖

    给平面上一些点 找到一个半径最小的圆 使得所有点在园内或者圆上

    = =这竟然有O(n)的做法。。。

    随机增量 代码实现也很简单

     以下来自这个博客

    algorithm:

    A、令Ci表示为前i个点的最小覆盖圆。当加入新点pi时如果pi不在Ci-1里那么pi必定在Ci的边界上。
    B、再从新考虑这样一个问题,Ci为前i个点最小覆盖圆且p在Ci的的边界上!同理加入新点pi时如果p

    i不在Ci-1里那么pi必定在Ci的边界上。这时我们就包含了两个点在这个最小圆的边界上。
    C、再从新考虑这样一个问题,Ci为前i个点最小覆盖圆且有两个确定点再边界上!此时先让

    O(N)的方法能够判定出最小圆。

    ------------------------------------------------------------------------------------

    analysis:

    现在来分析为什么是线性的。

    C是线性的这是显然的。

    B<-C的过程中。考虑pi 他在园内的概率为 (i-1)/i 。在圆外的概率为 1/i 所以加入pi的期望复杂度为:(1-i)/i*O(1) +(1/i)*O(i) {前者在园内那么不进入C,只用了O(1)。后者进入C用了O(i)的时间}这样分析出来,复杂度实际上仍旧

    是线性的。

    A<-B的过程中。考虑方法相同,这样A<-B仍旧是线性。于是难以置信的最小圆覆盖的复杂度变成了线性的。

     

    感觉就是看起来是3层循环 然而进入最后循环的概率只有 3/i 最后均摊一下是线性的

    ZOJ 1450 HDU 3007 都是板子题

     

    今天大部分时间都在搞数据。。。

    打算明天做一些第二期杂题

  • 相关阅读:
    STL map与Boost unordered_map
    static constructors in C++? need to initialize private static objects
    谈谈C++继承中的重载,覆盖和隐藏
    C++继承:公有,私有,保护
    C++ using关键字作用总结
    ++iter的效率比iter++的效率高
    C++中dynamic_cast,static_cast,const_cast,reinterpret_cast
    【转】WinForm中添加闪屏窗口的两种方法
    【转】一个不错的Matlab的gui界面设计实例 (20081003 15:47:30)matlab gui 界面 校园 分类:Matlab实例
    制作一个WinForm的闪屏
  • 原文地址:https://www.cnblogs.com/drzdk/p/7252772.html
Copyright © 2011-2022 走看看