★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公众号:山青咏芝(shanqingyongzhi)
➤博客园地址:山青咏芝(https://www.cnblogs.com/strengthen/)
➤GitHub地址:https://github.com/strengthen/LeetCode
➤原文地址:https://www.cnblogs.com/strengthen/p/10348304.html 
➤如果链接不是山青咏芝的博客园地址,则可能是爬取作者的文章。
➤原文已修改更新!强烈建议点击原文地址阅读!支持作者!支持原创!
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★

Given the radius and x-y positions of the center of a circle, write a function randPoint which generates a uniform random point in the circle.

Note:

  1. input and output values are in floating-point.
  2. radius and x-y position of the center of the circle is passed into the class constructor.
  3. a point on the circumference of the circle is considered to be in the circle.
  4. randPoint returns a size 2 array containing x-position and y-position of the random point, in that order.

Example 1:

Input:
["Solution","randPoint","randPoint","randPoint"]
[[1,0,0],[],[],[]]
Output: [null,[-0.72939,-0.65505],[-0.78502,-0.28626],[-0.83119,-0.19803]]

Example 2:

Input:
["Solution","randPoint","randPoint","randPoint"]
[[10,5,-7.5],[],[],[]]
Output: [null,[11.52438,-8.33273],[2.46992,-16.21705],[11.13430,-12.42337]]

Explanation of Input Syntax:

The input is two lists: the subroutines called and their arguments. Solution's constructor has three arguments, the radius, x-position of the center, and y-position of the center of the circle. randPoint has no arguments. Arguments are always wrapped with a list, even if there aren't any.


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

说明:

  1. 输入值和输出值都将是浮点数。
  2. 圆的半径和圆心的 x、y 坐标将作为参数传递给类的构造函数。
  3. 圆周上的点也认为是在圆中。
  4. 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 没有参数。输入参数是一个列表,即使参数为空,也会输入一个 [] 空列表。


拒绝采样的经典应用: [Swift]LeetCode470. 用 Rand7() 实现 Rand10() | Implement Rand10() Using Rand7()
Runtime: 736 ms
Memory Usage: 17.5 MB
 1 class Solution {
 2     var r:Double
 3     var centerX:Double
 4     var centerY:Double
 5
 6     init(_ radius: Double, _ x_center: Double, _ y_center: Double) {
 7         self.r = radius
 8         self.centerX = x_center
 9         self.centerY = y_center
10     }
11
12     func randPoint() -> [Double] {
13         while(true)
14         {
15             var x:Double = (2 * Double.random(in: 0..<1) - 1.0) * r
16             var y:Double = (2 * Double.random(in: 0..<1) - 1.0) * r
17
18             if x * x + y * y <= r * r
19             {
20                 return [centerX + x, centerY + y]
21             }
22         }
23     }
24 }
25
26 /**
27  * Your Solution object will be instantiated and called as such:
28  * let obj = Solution(radius, x_center, y_center)
29  * let ret_1: [Double] = obj.randPoint()
30  */
31  


Runtime: 748 ms

Memory Usage: 17.5 MB
 1 class Solution {
 2     var r:Double
 3     var centerX:Double
 4     var centerY:Double
 5
 6     init(_ radius: Double, _ x_center: Double, _ y_center: Double) {
 7         self.r = radius
 8         self.centerX = x_center
 9         self.centerY = y_center
10     }
11
12     func randPoint() -> [Double] {
13         var theta:Double = 2 * M_PI * (Double.random(in: 0..<1))
14         var len:Double = sqrt(Double.random(in: 0..<1)) * r
15         return [centerX + len * cos(theta), centerY + len * sin(theta)]
16     }
17 }
18
19 /**
20  * Your Solution object will be instantiated and called as such:
21  * let obj = Solution(radius, x_center, y_center)
22  * let ret_1: [Double] = obj.randPoint()
23  */
24  

转载于:https://www.cnblogs.com/strengthen/p/10348304.html

[Swift]LeetCode478. 在圆内随机生成点 | Generate Random Point in a Circle相关推荐

  1. 478. Generate Random Point in a Circle | 478. 在圆内随机生成点(Java)

    题目 https://leetcode.com/problems/generate-random-point-in-a-circle/ 题解 class Solution {double r, x, ...

  2. LeetCode 478. 在圆内随机生成点(概率)

    1. 题目 给定圆的半径和圆心的 x.y 坐标,写一个在圆中产生均匀随机点的函数 randPoint . 说明: 输入值和输出值都将是浮点数. 圆的半径和圆心的 x.y 坐标将作为参数传递给类的构造函 ...

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

    题目 难度:★★☆☆☆ 类型:几何 方法:拒绝采样 力扣链接请移步本题传送门 更多力扣中等题的解决方案请移步力扣中等题目录 给定圆的半径和圆心的 x.y 坐标,写一个在圆中产生均匀随机点的函数 ran ...

  4. 在一个圆内随机取若个坐标点(python)

    在一个指定位置的圆内随机取若干个坐标点,num为数量,radius为圆的半径,(centerx, centery)为圆心坐标. 方法一:根据条件判断的随机点产生方法 import random imp ...

  5. 在多边形内随机生成点

    在多边形内随机生成点 在多边形内随机生成点这个问题可以理解为判断一个点是否在多边形内. 最近项目有个需求,需要在地图区域随机生成一些点.完成后效果如下: 因为项目使用点是d3,所有优先考虑d3.js中 ...

  6. MATLAB实现圆内随机撒点

    已知圆的半径和圆心坐标以及要撒的点的个数,实现在院内随机撒点.结果如下: 代码如下: function [x,y]=DrawPoint(x0,y0,R,num_Dian) % 输入依次是:圆心横纵坐标 ...

  7. matlab 非均匀用户撒点,MATLAB实现圆内随机撒点

    已知圆的半径和圆心坐标以及要撒的点的个数,实现在院内随机撒点.结果如下: 代码如下: function [x,y]=DrawPoint(x0,y0,R,num_Dian) % 输入依次是:圆心横纵坐标 ...

  8. python在多边形内随机生成点_Python随机生成均匀分布在三角形内或者任意多边形内的点...

    Python有一随机函数可以产生[0,1)区间内的随机数,基于此函数生成随机分布在任意三角形内的点 由数学知识得知: 几何体的向量表达形式 直线: 线段: 推广到高维 三维平面: 三角形: 注释,v这 ...

  9. OpenCV入门系列 —— cv::minEnclosingCircle 随机生成点坐标并计算最小包围圆

    OpenCV入门系列 -- cv::minEnclosingCircle 随机生成点坐标并计算最小包围圆 前言 程序说明 输出结果 代码示例 前言 随着工业自动化.智能化的不断推进,机器视觉(2D/3 ...

最新文章

  1. C#判断文件及文件夹是否存在并创建
  2. 斗地主程序设计c语言,C语言斗地主游戏v0.1
  3. 线性八叉树_基于三维点云数据的线性八叉树编码压缩算法(权毓舒, 何明一,).pdf...
  4. 图的基本操作及其相关应用
  5. 除非得到你的首肯,否则别人无法伤害你——Leo网上答疑(20)
  6. zhuan zai suffix tree
  7. 微信小程序登录 getUserInfo:fail 登录用户不是该小程序的开发者
  8. 《C++ Primer》7.5.2节练习
  9. (十九)TCPIP面试宝典-进入大厂必备总结(上)
  10. 那年学过的Java笔记一SE基础
  11. 验证码识别服务提供商
  12. 清除zend studio10.5中的内置浏览器中的历史记录
  13. Redis命令 - sortedSet
  14. 人工智能各层思维导图
  15. 神秘消失的Windows 9,如今真被人做出来了
  16. nginx+uWSGI+django+virtualenv+supervisor发布web服务器流程
  17. unserialize():Error at offset 0 of 96 bytes是什么意思
  18. hdu 5296 Annoying problem(LCA)
  19. 晴天的魔法乐园——谢尔宾斯基地毯(递归打印图形)
  20. python时间序列平稳性检验_Python量化投资基础:时间序列的平稳性检验

热门文章

  1. js 判断字符串的结尾的字符串
  2. mysql的主从,主主,半同步
  3. curl 模拟表单提交
  4. ikvm.net简介
  5. 允许匿名用户访问VisualSVN
  6. 一些iphone开发的资料
  7. 气愤ing,身份证丢了到底要不要挂失?
  8. php xss 实例,php - 关于sql注入和xss的具体实例分析
  9. linux下mysql设置关联_Linux下mysql安装与配置
  10. oracle sysdate 截取年月日,oracle中extract()函数----用于截取年、月、日、时、分、秒...