标签:
旋转卡壳
到现在依然不确定要怎么读...
以最远点对问题为例,枚举凸包上的两个点是最简单的想法,时间复杂度O(n2)
我们想象用两条平行线卡着这个凸包,当其中一个向某个方向旋转的时候另一个显然也是朝同样的方向旋转
所以在枚举其中一条边的过程中完全没有必要重新枚举另一条边
而且对于一条边而言,凸包上的点到这条边的距离是满足单峰性质的
所以线性的做法就出来啦
↓代码非常短很优秀~
procedure Roatating_Calipers; begin stack[len+1]:=stack[1];j:=2; ans:=0; for i:=1 to len do begin while cross(stack[i],stack[i+1],stack[j])<cross(stack[i],stack[i+1],stack[j+1]) do j:=j mod len+1; ans:=max(ans,max(getdis(stack[i],stack[j]),getdis(stack[i+1],stack[j+1]))); end; end;
POJ2187 最远点对问题直接用RC
BZOJ1069 可以枚举一条对角线,在两边各找出一个点使得面积和最大,两边在保证在某个区间内的情况下做RC
BZOJ1185 是一道非常好的题,但目前还没有A掉...昨天奋战了一个晚上但在精度问题上还是卡住了
最小矩形根据黑书上的写法采用最小角前进,然而黄学长的做法代码又短又好看
发现只要引入点积会有一些奇妙的性质
在确定了一条边的时候找最远的边直接是裸的RC
然而怎么找这个矩形里最左的点和最右的点?
结论:点积越大越右,点积越小越左。
这个稍加证明即可。
标签:
原文地址:http://www.cnblogs.com/mjy0724/p/4423905.html