python生成一个圆_478. 在圆内随机生成点(Python)

题目

难度:★★☆☆☆

类型:几何

方法:拒绝采样

力扣链接请移步本题传送门

更多力扣中等题的解决方案请移步力扣中等题目录

给定圆的半径和圆心的 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解决方案,请移步力扣中等题解析

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值