Hal Burch
Farmer John wishes to build a fence to contain his cows, but he's a bit short on cash right. Any fence he builds must contain all of the favorite grazing spots for his cows. Given the location of these spots, determine the length of the shortest fence which encloses them.
PROGRAM NAME: fc
INPUT FORMAT
The first line of the input file contains one integer, N. N (0 <= N <= 10,000) is the number of grazing spots that Farmer john wishes to enclose. The next N line consists of two real numbers, Xi and Yi, corresponding to the location of the grazing spots in the plane (-1,000,000 <= Xi,Yi <= 1,000,000). The numbers will be in decimal format.
SAMPLE INPUT (file fc.in)
4 4 8 4 12 5 9.3 7 8
OUTPUT FORMAT
The output should consists of one real number, the length of fence required. The output should be accurate to two decimal places.
SAMPLE OUTPUT (file fc.out)
12.00
最水的凸包啦,分析:由三角不等式可推出,使用凸包来包围所有的点,周长最小
刚好算法分析的课本上讲了个分治解凸包的算法,于是决定试一试,结果tmd各种纠结(特别是在合并两个凸包的时候),真是百思不得其解为神马复杂度同为O(nlogn),却硬要这样解呢?
最后还是用回直接扫描,本来以为还要考虑精度问题,先试试提交再说,结果就过了,orz。。。
PS:要考虑一种特殊的情况我也没写进去:假设a、b、c三点的极坐标角相同,那些对它们进行排序的时候就应该按距离r升序或者降序排列。不过这道题的数据确实很难做到这一点——因为每个人选择观察者位置的时候都可能会有自己特殊的想法,所以这个漏洞就不怪USACO啦~
代码: