美文网首页
478. 在圆内随机生成点(Python)

478. 在圆内随机生成点(Python)

作者: 玖月晴 | 来源:发表于2020-10-26 19:21 被阅读0次

题目

难度:★★☆☆☆
类型:几何
方法:拒绝采样

力扣链接请移步本题传送门
更多力扣中等题的解决方案请移步力扣中等题目录

给定圆的半径和圆心的 x、y 坐标,写一个在圆中产生均匀随机点的函数 randPoint 。

说明:

输入值和输出值都将是浮点数。
圆的半径和圆心的 x、y 坐标将作为参数传递给类的构造函数。
圆周上的点也认为是在圆中。
randPoint 返回一个包含随机点的x坐标和y坐标的大小为2的数组。
示例 1:

输入:
["Solution","randPoint","randPoint","randPoint"]
[[1,0,0],[],[],[]]
输出: [null,[-0.72939,-0.65505],[-0.78502,-0.28626],[-0.83119,-0.19803]]
示例 2:

输入:
["Solution","randPoint","randPoint","randPoint"]
[[10,5,-7.5],[],[],[]]
输出: [null,[11.52438,-8.33273],[2.46992,-16.21705],[11.13430,-12.42337]]
输入语法说明:

输入是两个列表:调用成员函数名和调用的参数。Solution 的构造函数有三个参数,圆的半径、圆心的 x 坐标、圆心的 y 坐标。randPoint 没有参数。输入参数是一个列表,即使参数为空,也会输入一个 [] 空列表。

解答

方法1:拒绝采样

我们在以圆心为中心,以二倍半径为边长的正方形内部进行随机选点,当点落在圆内或者圆上时,满足条件,返回该点。

import random


class Solution:

    def __init__(self, radius: float, x_center: float, y_center: float):
        self.radius = radius
        self.x_center = x_center
        self.y_center = y_center

    def randPoint(self):
        while True:
            x = self.x_center + (random.random() - 0.5) * self.radius * 2
            y = self.y_center + (random.random() - 0.5) * self.radius * 2
            if (x - self.x_center) ** 2 + (y - self.y_center) ** 2 <= self.radius ** 2:
                return x, y

方法2:极坐标

我们可以把上面的直角坐标变换为极坐标,随机的选取角度和半径,生成的点一定在圆上或者圆内。这里需要注意,由于在平面维度是均匀采样的,生成随机半径时需要对结果开方。


import math
import random


class Solution:

    def __init__(self, radius: float, x_center: float, y_center: float):
        self.radius = radius
        self.x_center = x_center
        self.y_center = y_center

    def randPoint(self):

        theta = random.random() * 2 * math.pi
        r = random.random() ** 0.5 * self.radius

        x = self.x_center + r * math.cos(theta)
        y = self.y_center + r * math.sin(theta)

        return x, y

如有疑问或建议,欢迎评论区留言~

有关更多力扣中等题的python解决方案,请移步力扣中等题解析

相关文章

  • 478. 在圆内随机生成点(Python)

    题目 难度:★★☆☆☆类型:几何方法:拒绝采样 力扣链接请移步本题传送门[https://leetcode-cn....

  • 478. 在圆内随机生成点

    给定圆的半径和圆心的位置,实现函数 randPoint ,在圆中产生均匀随机点。 实现 Solution 类: S...

  • 每日一题-478. 在圆内随机生成点

    给定圆的半径和圆心的位置,实现函数 randPoint ,在圆中产生均匀随机点。 实现 Solution 类: S...

  • Python小函数

    生成随机数 生成指定范围内的浮点数: 参考链接:python生成随机数方法小结 进制转换 二进制到十进制:

  • Python生成随机点

    坐标位于某个矩形内 该序列位于某个圆形内【方法一:拒绝采样】 该序列位于某个圆形内【方法二:极坐标】 随机点可视化...

  • python必知必会6

    Python中生成随机整数、随机小数、0—1之间小数方法 生成随机整数使用random.randint()生成随机...

  • python生成随机数

    python 生成随机数

  • 8. python如何创建随机序列

    如何创建随机序列 在python中的random.randint(a,b)用于生成一个指定范围内的整数。其中参数a...

  • Excel怎么生成随机数?

    Excel怎么生成随机数?如何生成指定范围内的随机数呢?可以在Excel中使用函数,生成随机数。 1、在单元格中输...

  • Python常见面试题(二)

    python生成随机函数 random模块 random.random()随机生成0-1之间的数字 random....

网友评论

      本文标题:478. 在圆内随机生成点(Python)

      本文链接:https://www.haomeiwen.com/subject/helzmktx.html