其他分享
首页 > 其他分享> > 【经典问题】maximum subset sum of vectors

【经典问题】maximum subset sum of vectors

作者:互联网

AtCoder Beginner Contest 139 Task F Engines

题目大意

给定 $n$ 个二维向量,从中选出若干个,使得它们的和的模最大。

分析

这是一个经典问题,还有一种提法是:

给定 $n$ 个二维向量 $v_1, v_2, \dots, v_n$,求一组系数 $a_1, a_2, \dots, a_n$($0 \le a_i \le 1$)使得 $\sum_{i = 1}^{n} a_i v_i$ 的模最大。
容易证明:对于最优解,$a_i$ 要么是 1 要么是 0;于是规约到选择一个最优的子集的问题。

可以证明,最优解满足下列两个性质:

如果加上「所选的向量都在一个的半平面中」这个限制,我们立即可以推论出,若先把所有向量按极角排序,则所选的那些向量必定是连续的一段。换言之,

References

https://math.stackexchange.com/q/730611/538611

标签:subset,le,sum,vectors,using,最优,向量,按极角
来源: https://www.cnblogs.com/Patt/p/11535310.html