mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-01-25 17:50:26 +08:00
35 lines
1.5 KiB
HTML
35 lines
1.5 KiB
HTML
<p>Given the radius and the position of the center of a circle, implement the function <code>randPoint</code> which generates a uniform random point inside the circle.</p>
|
|
|
|
<p>Implement the <code>Solution</code> class:</p>
|
|
|
|
<ul>
|
|
<li><code>Solution(double radius, double x_center, double y_center)</code> initializes the object with the radius of the circle <code>radius</code> and the position of the center <code>(x_center, y_center)</code>.</li>
|
|
<li><code>randPoint()</code> returns a random point inside the circle. A point on the circumference of the circle is considered to be in the circle. The answer is returned as an array <code>[x, y]</code>.</li>
|
|
</ul>
|
|
|
|
<p> </p>
|
|
<p><strong>Example 1:</strong></p>
|
|
|
|
<pre>
|
|
<strong>Input</strong>
|
|
["Solution", "randPoint", "randPoint", "randPoint"]
|
|
[[1.0, 0.0, 0.0], [], [], []]
|
|
<strong>Output</strong>
|
|
[null, [-0.02493, -0.38077], [0.82314, 0.38945], [0.36572, 0.17248]]
|
|
|
|
<strong>Explanation</strong>
|
|
Solution solution = new Solution(1.0, 0.0, 0.0);
|
|
solution.randPoint(); // return [-0.02493, -0.38077]
|
|
solution.randPoint(); // return [0.82314, 0.38945]
|
|
solution.randPoint(); // return [0.36572, 0.17248]
|
|
</pre>
|
|
|
|
<p> </p>
|
|
<p><strong>Constraints:</strong></p>
|
|
|
|
<ul>
|
|
<li><code>0 < radius <= 10<sup>8</sup></code></li>
|
|
<li><code>-10<sup>7</sup> <= x_center, y_center <= 10<sup>7</sup></code></li>
|
|
<li>At most <code>3 * 10<sup>4</sup></code> calls will be made to <code>randPoint</code>.</li>
|
|
</ul>
|