转自http://hi.baidu.com/convexhull/blog/item/9995950088b44c4ef919b8a0.html
问题描述:
给定平面上n个外切和相离的圆,每圆都不包含坐标原点且过原点做每个圆的切线,任意两个切线之间的夹角不小于1e-6。
现在从坐标原点发出射线,求至少有多少条射线使得每个圆都被一条射线穿过。注:(0 <= n <= 1000)。
问题分析:
如下图,给定的三个圆可以被一条射线同时穿过。每个圆在
这篇博客介绍了如何解决一个计算机科学竞赛问题——在平面上有n个外切且相离的圆,要求找出至少多少条射线能穿过每个圆。通过将圆转化为角度区间,并处理角度的周期性,使用贪心策略寻找最少的射线数量。问题的关键在于处理区间跨越x负半轴的情况以及正确应用贪心算法。
转自http://hi.baidu.com/convexhull/blog/item/9995950088b44c4ef919b8a0.html
问题描述:
给定平面上n个外切和相离的圆,每圆都不包含坐标原点且过原点做每个圆的切线,任意两个切线之间的夹角不小于1e-6。
现在从坐标原点发出射线,求至少有多少条射线使得每个圆都被一条射线穿过。注:(0 <= n <= 1000)。
问题分析:
如下图,给定的三个圆可以被一条射线同时穿过。每个圆在

被折叠的 条评论
为什么被折叠?