poj 1118 Lining Up || poj 2780 Linearity || poj 2606 Rabbit hunt

本文详细介绍了如何通过优化算法解决特定类型的几何问题,从原始的O(N^3)复杂度优化至更高效的O(N^2*logN)。通过枚举每个点作为起点,计算与该点的斜率并进行排序,从而实现了问题的有效求解。此外,文章还指出了优化过程中的注意事项,并提供了两种不同版本的代码实现,以供读者参考。

本来1118没想起来什么方法,O(N^3)过了,去百度搜看有啥好方法没,搜到了好几道这样的题,代码一贴,改改输入,改改数组范围,居然都过了,我表示。。。无语了。。

 

一个优化方法是,枚举每个点为起点,然后求得每个点和这个点的斜率,然后对斜率排序,然后再统计。N^2*LOGN的时间复杂度,140+MS过了。

 

 


 

 

P.S.经HS童鞋说明,确实木有考虑斜率不存在的情况,优化版的代码改了下。

 

无优化版

 

优化版

 

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值