LeetCode每日一题——478. 在圆内随机生成点

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

题目

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

实现 Solution 类:

Solution(double radius, double x_center, double y_center) 用圆的半径 radius 和圆心的位置 (x_center, y_center) 初始化对象

randPoint() 返回圆内的一个随机点。圆周上的一点被认为在圆内。答案作为数组返回 [x, y] 。

提示

示例 1:

输入: [“Solution”,“randPoint”,“randPoint”,“randPoint”] [[1.0, 0.0,

0.0], [], [], []]

输出: [null, [-0.02493, -0.38077], [0.82314, 0.38945], [0.36572, 0.17248]]

解释: Solution solution = new Solution(1.0, 0.0, 0.0);

solution.randPoint ();//返回[-0.02493,-0.38077] solution.randPoint ();//返回[0.82314,0.38945] solution.randPoint ();//返回[0.36572,0.17248]

提示:

0 < radius <= 108

-107 <= x_center, y_center <= 107

randPoint 最多被调用 3 * 104 次

思路

1.在给定圆的外界矩形内生成随机点,即x在[圆心横坐标-半径,圆心横坐标+坐标],y在[圆心纵坐标-半径,圆心纵坐标+半径]生成随机浮点数

2.这样生成的随机数可能在圆外,需要根据两点直接的距离和半径大小比较,即((x - self.x_center) **2 + (y - self.y_center) **2) 和 self.radius **2做比较判断该点是否在圆内,在圆内直接返回,不在圆内重新生成一个点重复上述步骤。

题解

class Solution:
    x,y = (), ()
    x_center, y_center, radius = 0.0, 0.0, 0.0
    def __init__(self, radius: float, x_center: float, y_center: float):
        self.x = (x_center - radius, x_center + radius)
        self.y = (y_center - radius, y_center + radius)
        self.x_center = x_center
        self.y_center = y_center
        self.radius = radius
    def randPoint(self) -> List[float]:
        a = random.uniform(self.x[0], self.x[1])
        b = random.uniform(self.y[0], self.y[1])
        while ((a - self.x_center) **2 + (b - self.y_center) **2) > self.radius **2 :
            a = random.uniform(self.x[0], self.x[1])
            b = random.uniform(self.y[0], self.y[1])
        return [a,b]
# Your Solution object will be instantiated and called as such:
# obj = Solution(radius, x_center, y_center)
# param_1 = obj.randPoint()
目录
相关文章
(Java)链表OJ题---LeetCode 138 复制带随机指针的链表
给你一个长度为 n 的链表,每个节点包含一个额外增加的随机指针 random ,该指针可以指向链表中的任何节点或空节点。构造这个链表的 深拷贝。 深拷贝应该正好由 n 个 全新 节点组成,其中每个新节点的值都设为其对应的原节点的值。新节点的 next 指针和 random 指针也都应指向复制链表中的新节点,并使原链表和复制链表中的这些指针能够表示相同的链表状态。复制链表中的指针都不应指向原链表中的节点 。例如,如果原链表中有 X 和 Y 两个节点,其中 X.random --> Y 。那么在复制链表中对应的两个节点 x 和 y ,同样有 x.random --> y 。
(Java)链表OJ题---LeetCode 138 复制带随机指针的链表
|
程序员
【Leetcode】拿捏链表(五)——138. 复制带随机指针的链表
【Leetcode】拿捏链表(五)——138. 复制带随机指针的链表
78 0
【Leetcode】拿捏链表(五)——138. 复制带随机指针的链表
|
Java Python
LeetCode 第 138 题:复制带随机指针的链表(Python 代码)
给定一个长度为 n 的链表,每个节点比普通的节点多了一个额外的随机指针 ramdom,该指针可以指向链表中的任何节点或空节点。构造这个链表的深拷贝。所谓的深拷贝,就是完全生成一个新的对象,内存地址都是不同的,这样改变拷贝之前变量,就不会影响到拷贝的变量。
110 0
|
算法
Leetcode每日一题——随机翻转矩阵
给你一个 m x n 的二元矩阵 matrix ,且所有值被初始化为 0 。请你设计一个算法,随机选取一个满足 matrix[i][j] == 0 的下标 (i, j) ,并将它的值变为 1 。
113 0
|
算法 Java 虚拟化
LeetCode(算法)- 138. 复制带随机指针的链表
LeetCode(算法)- 138. 复制带随机指针的链表
82 0
LeetCode(算法)- 138. 复制带随机指针的链表
|
机器学习/深度学习 存储 API
【刷穿 LeetCode】528. 按权重随机选择 :「前缀和 + 二分」&「模拟(桶轮询)」
【刷穿 LeetCode】528. 按权重随机选择 :「前缀和 + 二分」&「模拟(桶轮询)」
|
算法 索引
​LeetCode刷题实战380:O(1) 时间插入、删除和获取随机元素
算法的重要性,我就不多说了吧,想去大厂,就必须要经过基础知识和业务逻辑面试+算法面试。所以,为了提高大家的算法能力,这个公众号后续每天带大家做一道算法题,题目就从LeetCode上面选 !
148 0
​LeetCode刷题实战380:O(1) 时间插入、删除和获取随机元素
|
算法 索引
​LeetCode刷题实战138:复制带随机指针的链表
算法的重要性,我就不多说了吧,想去大厂,就必须要经过基础知识和业务逻辑面试+算法面试。所以,为了提高大家的算法能力,这个公众号后续每天带大家做一道算法题,题目就从LeetCode上面选 !
97 0
​LeetCode刷题实战138:复制带随机指针的链表
|
算法
​LeetCode刷题实战519:随机翻转矩阵
算法的重要性,我就不多说了吧,想去大厂,就必须要经过基础知识和业务逻辑面试+算法面试。所以,为了提高大家的算法能力,这个公众号后续每天带大家做一道算法题,题目就从LeetCode上面选 !
139 0