题目:一个任意多边形,判断是否能放入一个半径为r的圆
?一开始以为是半平面交,果断看大家的提交时间和代码长度就不像是,不过还是提交了一发,果断WA.
后来被昀昀科普了,凹多边形是不可以这么求的。凹多边形可能没有核,向内推近r后求核,显然是不对的。
点不是很多,那就只有模拟退火了,貌似不是只有。。。
要写这题,首先还得写个判断点是否在多边形内,因为以前写得太矬,打算重新写一个,然后就折腾了一晚上,各种错误,老是用直线去代替线段。有了这个判断,便可以开始模拟退火
模拟退火关键问题在于火候怎么把握,一开始尝试选取n个点,步长每次减小1/10,精度控制在1e-3,竟然TLE,看了网上的代码,也是这么多。然后开始各种尝试,果断减小选取的点数。各种WA,TLE无语。。。
有位好心的ACMER,给了一组数据
4
0 0
0 2
2 2
2 0
1
一般如果在判断的时候要求精度太高的话,这组数据过不了,果断不原本1e-8的精度改成1e-3,一通乱改之后,可以说是勉强通过了这组数据。
大清早的起来又是刷屏,各种尝试火候,最终还是刷进了200ms
最多选 20个点,每个点走5步,步长为原来的0.55,之前的TLE主要原因就是那组数据出不来,而且会WA。
[cpp]?
#include?
#include?
#include?
#include?
#include?
#include?
#include?
#include?
#include?
#include