现在的位置: 首页 > 综合 > 正文

pku 3304 Segments

2012年11月13日 ⁄ 综合 ⁄ 共 1735字 ⁄ 字号 评论关闭

网上很多人给出了解题思路的了,自己也是根据大牛们的思路做了,小弟很少做计算几何的问题,因为这道题涉及到比较严格的精度控制的问题,所以记录一下以备自己以后复习查看。。

 

思路(都是转载别人的):

 

首先题中的要求等价于:存在一条直线l和所有的线段都相交。
证明:若存在一条直线l和所有线段相交,作一条直线m和l垂直,则m就是题中要求的直线,所有线段投影的一个公共点即为垂足。(l和每条线段的交点沿l投影到m上的垂足处)
反过来,若存在m,所有线段在m上的投影有公共点,则过这点垂直于m作直线l,l一定和所有线段相交。

然后证存在l和所有线段相交等价于存在l过某两条线段的各一个端点且和所有线段相交。
充分性显然。必要性:若有l和所有线段相交,则可保持l和所有线段相交,左右平移l到和某一线段交于端点停止(“移不动了”)。然后绕这个交点旋转。也是转到“转不动了”(和另一线段交于其一个端点)为止。这样就找到了一个新的l。
于是本题可归结为枚举两两线段的各一个端点,连一条直线,再判断剩下的线段是否都和这条直线有交点。

在discuss有人给出两个容易出错的地方,自己错了两次,但根据这里一改就ac了
1.需要考虑当n=1的情况,当然n=1和2都是Yes。
2.在枚举所有顶点的时候考虑一下顶点的距离小于1.0*10^(-8)时是不用考虑的。

 

 

 

 

抱歉!评论已关闭.