2016.12.12  T1

  给n个圆,保证圆圆相离,求将圆围起来的最小周长。n<=100

  

  就像上图。考场上,我就想用切线的角度来做凸包。以圆心x,y排序,像点凸包一样,不过用两圆之间的下切线角度来判断。

  这就是下切线(我自己瞎编的名字):

好像是对的啊:

然后我就保证必AC的希望,用这种写法交了,然后就只得了N=2的暴力分。。。

自以为是正解,却落得如此下场。。。

为什么?这样不对吗?借用学长的力量,果然被Hack掉了:

  这种情况,圆心排序后,检测的顺序并不是圆上的切点的顺序,自然就会挂。

  蓝瘦香菇之后,我开始反思我对凸包的理解:为什么不能这么做?凸包的本质是什么?上面看到这样一句话:“检测的顺序并不是圆上的切点的顺序”。顺序,是关键么?如果我们可以把圆上所又点加入数组(当然,这是个无限集合),那么每一个凸包上的点都来自于这个集合内的点,于是,就可以用凸包来做了。但是计算机实际上是一个有限状态机,无限状态的问题是没有办法解决的。那么就是说,只有拿来排序的点是和凸包上的点的顺序一致,那么,做凸包就没有问题,否则,就有不能这样做。回过头来,再来看这道题:哪些点是和凸包上的点顺序一定一致的呢?当然是圆上的点咯。凸包上的点,除了弧线,就是切线了。弧线不好表示,而切线可以用切点确定,而弧线有恰好两端都在切点上。所以,就可以拿切点来做为排序依据。那么解法就浮出水面了。

  还好,这样一来,我对凸包的理解又深了一步,还有下次考试嘛↖(^ω^)↗!除此之外,还有个考试技巧:N<=100。。。nlogn就想AC?等着WA吧!!!

  拓展:

  如果圆的半径相等呢?可不可以用圆心做凸包呢?

  可以咯。可以把圆心上的连线平移到圆上,是等价的:

总结:

1.拿来排序的点应该和凸包上的点的顺序一致

2.可以利用特殊点来确定奇形凸包

你还能获得什么启发呢?

关于2016.12.12——T1的反思:凸包的意义与应用的更多相关文章

  1. JZOJ2020年8月12日提高组反思

    JZOJ2020年8月12日提高组反思 真·难亿一点点 T1 题目长并附带伤害-- 暴力搜 对于字符串,我选择\(Pascal\) T2 概率问题,再见 T3 样例没懂,再见 T4 有史以来见过的条件 ...

  2. 2016年12月31日 星期六 --出埃及记 Exodus 21:26

    2016年12月31日 星期六 --出埃及记 Exodus 21:26 "If a man hits a manservant or maidservant in the eye and d ...

  3. 2016年12月30日 星期五 --出埃及记 Exodus 21:25

    2016年12月30日 星期五 --出埃及记 Exodus 21:25 burn for burn, wound for wound, bruise for bruise.以烙还烙,以伤还伤,以打还打 ...

  4. 2016年12月29日 星期四 --出埃及记 Exodus 21:24

    2016年12月29日 星期四 --出埃及记 Exodus 21:24 eye for eye, tooth for tooth, hand for hand, foot for foot,以眼还眼, ...

  5. 2016年12月28日 星期三 --出埃及记 Exodus 21:23

    2016年12月28日 星期三 --出埃及记 Exodus 21:23 But if there is serious injury, you are to take life for life,若有 ...

  6. 2016年12月27日 星期二 --出埃及记 Exodus 21:22

    2016年12月27日 星期二 --出埃及记 Exodus 21:22 "If men who are fighting hit a pregnant woman and she gives ...

  7. c++中变量声明和变量定义的区别。2016年12月6日

    整个流程: 1.程序告诉cpu,程序将要使用一个变量.(暂时不一定用到,先说一下.) 2.程序告诉CPU,程序现在就要使用一个变量.(现在就用) 3.cpu按照这个变量的类型,把内存划分出几个单位(b ...

  8. 2016年12月26日 星期一 --出埃及记 Exodus 21:21

    2016年12月26日 星期一 --出埃及记 Exodus 21:21 but he is not to be punished if the slave gets up after a day or ...

  9. 2016年12月25日 星期日 --出埃及记 Exodus 21:20

    2016年12月25日 星期日 --出埃及记 Exodus 21:20 "If a man beats his male or female slave with a rod and the ...

随机推荐

  1. Linux学习之四--Nginx

    关于Nginx的 nginx的是一个高性能的Web服务器的软件.它比Apache HTTP服务器更加灵活,重量轻的程序. 本教程将教你如何安装和你的CentOS 7服务器上启动Nginx的.   先决 ...

  2. android-获得".apk"文件的相关信息。包名、版本号等等

    String filePath = "/sdcard/feijiedemo.apk"; PackageManager packageManager = getPackageMana ...

  3. 项目vue2.0仿外卖APP(六)

    goods 商品列表页开发 布局编写 除了商品之外还有购物车,还有个详情页,挺复杂的. 两栏布局:左侧固定宽度,右侧自适应,还是用flex. 因为内容可能会超过手机高度,超过就隐藏.左右两侧的内容是可 ...

  4. bzoj 4695: 最假女选手

    ……一道丧病线段树膜板题…… 被常数卡的死去活来……QAQ 学到了些奇技淫巧:把取min标记 和 区间最小值 合并 可以快很多…… #include <bits/stdc++.h> #de ...

  5. CSS标签

    CSS类选择器被大量使用了 class = cssname

  6. 解决ssh localhost中root@localhost:要求输入密码问题(已经进行了无密码设置登录)

    首先删除~/.ssh目录下的3个文件,如下 id_rsa authorized_keys id_rsa.pub 然后 exit # 退出刚才的 ssh localhostcd ~/.ssh/ # 若没 ...

  7. java内存溢出和内存泄露

    虽然jvm可以通过GC自动回收无用的内存,但是代码不好的话仍然存在内存溢出的风险. 最近在网上搜集了一些资料,现整理如下: —————————————————————————————————————— ...

  8. springmvc session和model解析

    关于springMVC中的session,有2种使用方法,第一种是直接传递httpsession,第二种是使用@SessionAttributes("userId") 注解 这里附 ...

  9. Redis基本信息

    1.Windows安装地址 https://github.com/MSOpenTech/redis/releases 2.命令行方式运行 执行redis-cli.exe 3.待续

  10. Hadoop HA高可用性架构和演进分析(转)

    1.概况 截至目前,Apache Hadoop版本分为两代,我们将第一代Hadoop称为Hadoop 1.0,第二代Hadoop称为Hadoop 2.0.前者主要有如下几种实现方式:1)社区版本基于S ...