eolymp
bolt
Спробуйте наш новий інтерфейс для відправки розв'язків
Задачі

Anchored Balloon

Anchored Balloon

A balloon placed on the ground is connected to one or more anchors on the ground with ropes. Each rope is long enough to connect the balloon and the anchor. No two ropes cross each other. \textit{\textbf{Figure 1}} shows such a situation. \includegraphics{https://static.e-olymp.com/content/f5/f59566ce4d4dcb81f07d5f8e5deb4ab3832ce93b.jpg} \textit{\textbf{Figure 1}}: A balloon and ropes on the ground Now the balloon takes off, and your task is to find how high the balloon can go up with keeping the rope connections. The positions of the anchors are fixed. The lengths of the ropes and the positions of the anchors are given. You may assume that these ropes have no weight and thus can be straightened up when pulled to whichever directions. \textit{\textbf{Figure 2}} shows the highest position of the balloon for the situation shown in \textit{\textbf{Figure 1}}. \includegraphics{https://static.e-olymp.com/content/16/16e857e58578949c291097bb00de43f156ab1840.jpg} \textit{\textbf{Figure 2}}: The highest position of the balloon \InputFile The input consists of multiple datasets, each in the following format. \textbf{n} \textbf{x_1 y_1 l_1} \textbf{...} \textbf{x_n y_n l_n} The first line of a dataset contains an integer \textbf{n} (\textbf{1} ≤ \textbf{n} ≤ \textbf{10}) representing the number of the ropes. Each of the following \textbf{n} lines contains three integers, \textbf{x_i}, \textbf{y_i}, and \textbf{l_i}, separated by a single space. \textbf{P_i = (x_i, y_i)} represents the position of the anchor connecting the \textbf{i}-th rope, and \textbf{l_i} represents the length of the rope. You can assume that \textbf{−100 }≤ \textbf{x_i} ≤ \textbf{100}, \textbf{−100} ≤ \textbf{y_i} ≤ \textbf{100}, and \textbf{1} ≤ \textbf{l_i} ≤ \textbf{300}. The balloon is initially placed at \textbf{(0, 0)} on the ground. You can ignore the size of the balloon and the anchors. You can assume that \textbf{P_i} and \textbf{P_j} represent different positions if \textbf{i} ≠ \textbf{j}. You can also assume that the distance between \textbf{P_i} and \textbf{(0, 0)} is less than or equal to \textbf{l_i−1}. This means that the balloon can go up at least \textbf{1} unit high. \textit{\textbf{Figures 1}} and \textit{\textbf{2}} correspond to the first dataset of Sample Input below. The end of the input is indicated by a line containing a zero. \OutputFile For each dataset, output a single line containing the maximum height that the balloon can go up. The error of the value should be no greater than \textbf{0.00001}. No extra characters should appear in the output.
Ліміт часу 8 секунд
Ліміт використання пам'яті 64 MiB
Вхідні дані #1
3
10 10 20
10 -10 20
-10 10 120
1
10 10 16
2
10 10 20
10 -10 20
2
100 0 101
-90 0 91
2
0 0 53
30 40 102
3
10 10 20
10 -10 20
-10 -10 20
3
1 5 13
5 -3 13
-3 -3 13
3
98 97 168
-82 -80 193
-99 -96 211
4
90 -100 160
-80 -80 150
90 80 150
80 80 245
4
85 -90 290
-80 -80 220
-85 90 145
85 90 170
5
0 0 4
3 0 5
-3 0 5
0 3 5
0 -3 5
10
95 -93 260
-86 96 211
91 90 177
-81 -80 124
-91 91 144
97 94 165
-90 -86 194
89 85 167
-93 -80 222
92 -84 218
0
Вихідні дані #1
17.3205081
16.0000000
17.3205081
13.8011200
53.0000000
14.1421356
12.0000000
128.3928757
94.1879092
131.1240816
4.0000000
72.2251798
Джерело ACM International Collegiate Programming Contest, Japan Domestic Contest, Aizu, Japan, 2013-07-12