AT_abc139_f [ABC139F] Engines

题目描述

E869120 君一开始站在二维平面上的原点 $(0, 0)$。 他有 $N$ 个引擎。每个引擎的使用方法和功能如下: - 使用第 $i$ 个引擎时,E869120 君当前位置的 $X$ 坐标会增加 $x_i$,$Y$ 坐标会增加 $y_i$。也就是说,如果他当前在坐标 $(X, Y)$,使用第 $i$ 个引擎后会移动到 $(X + x_i, Y + y_i)$。 - 引擎可以按任意顺序使用,但每个引擎最多只能使用一次。也可以选择不使用某些引擎。 他想要到达距离原点最远的位置。 请你求出他最后能到达的点 $(X, Y)$ 到原点的距离 $\sqrt{X^2 + Y^2}$ 的最大值。

输入格式

输入从标准输入读入,格式如下: > $N$ > $x_1$ $y_1$ > $x_2$ $y_2$ > $\vdots$ > $x_N$ $y_N$

输出格式

请输出他最后能到达的点到原点的距离的最大值,结果为实数。 只要你的答案与真实答案的相对误差或绝对误差在 $10^{-10}$ 以内,即视为正确。

说明/提示

### 限制条件 - $1 \leq N \leq 100$ - $-1\,000\,000 \leq x_i \leq 1\,000\,000$ - $-1\,000\,000 \leq y_i \leq 1\,000\,000$ - 输入均为整数 ### 样例解释 1 如果合理使用引擎,最后能到达的点到原点的距离可以达到 $10$。有以下三种方法可以实现: - 使用引擎 $1$,移动到 $(0, 10)$ - 先用引擎 $2$ 移动到 $(5, -5)$,再用引擎 $3$ 移动到 $(0, -10)$ - 先用引擎 $3$ 移动到 $(-5, -5)$,再用引擎 $2$ 移动到 $(0, -10)$ 没有办法让距离超过 $10$,所以最大值为 $10$。 ### 样例解释 2 最后能到达的点到原点的最大距离是 $2\sqrt{2} = 2.82842\ldots$。 一种实现方法是: - 先用引擎 $1$ 移动到 $(1, 1)$,再用引擎 $2$ 移动到 $(2, 1)$,最后用引擎 $3$ 移动到 $(2, 2)$ ### 样例解释 3 如果按顺序使用引擎 $1 \rightarrow 2 \rightarrow 3 \rightarrow 4 \rightarrow 5$,最终会到达 $(15, 15)$,距离原点为 $15\sqrt{2} = 21.2132\ldots$。 ### 样例解释 4 也有可能存在 $(x_i, y_i) = (0, 0)$,即没有任何作用的引擎。 ### 样例解释 5 请注意,也可能只有 $1$ 个引擎。 ### 样例解释 6 也可能只有 $2$ 个引擎。 由 ChatGPT 4.1 翻译