壹 

想着好久没做笔试题了,去GitHub找了面试相关的项目,结果被第一道题难住了.....说难其实也不难,而是我忘记了取范围随机整数怎么写了,不可否认如果当时是我在笔试,肯定也凉了,那么就由这道题引出本文。

对了,如果你要取范围整数的方法,请跳到文章尾部,但如果你想知道为什么这么写,请阅读本文,那么本文开始:

题目来源

 贰  关于random()

若要取随机整数,前提得知道数组API中的Math.random()方法能取0--1的随机数,它的范围是[0,1),也就是取包括0但不包括1的随机数。

其次,数组API中有一个Math.floor()方法代表向下取整,Math.floor(X)的代表的是取≤ X 且最接近X的整数。

那么我们可以通过Math.random()先取得随机数,再通过乘法计算得到大致范围,最后通过Math.floor()进行取整加工就可以达到目的了。

1.取[n,m)范围随机整数

比如,我要取 [0,100) 范围的随机整数,包括0但不包括100:

//[0,1)*100 => [0,100) 范围是0-99.99999...随机数
Math.random() * 100;
//向下取整加工,范围变成 0-99
Math.floor(Math.random() * 100);

0-100好理解一点,那我们怎么取 [2,32) 之间随机整数呢,思路相同:

当random取到0时,我们希望最后结果是2,所以需要有个加2的操作,那么32的情况只能拆分成30 + 2,所以应该是先乘法得到30,再有个加2的操作,像这么写:

Math.floor(Math.random() * 30) + 2;

结合上面2个例子,我们大概可以得出一个规律,取 [n,m) 包括n但不包括m的随机整数公式:

Math.floor(Math.random() * (m-n)) + n;

2.取[n,m]范围随机整数

如何取得包含n且包含m的随机整数呢,我们还是以好计算的[0,100]为例子。

按照前面的写法无法取到100,怎么办呢,我们直接在计算时得到一个100.99999,然后向下取整不就是100了,所以我们需要在乘以100的基础上再加上一个1。

需要注意的是加1操作的不能在random乘法计算完之后,你想想如果是乘完后加1,假设random乘法得到0再加个1,那最少的数字就是1了,所以加1必须是在乘法的时候加,所以应该是这样:

Math.floor(Math.random() * 101);

这样根据 [0,1) 的范围算出来的范围就是 [0,101),因为不包括101,所以就是[0,100]了。

针对 [2,32] 呢,简单分析一波,random是0时,我们希望得到2;假设random可以是1,我们希望得算出一个33才行,这样向下取整就能包含32了。

根据上面的分析,所以我们得让random乘法得到一个31,然后再加一个2,应该这么写:

Math.floor(Math.random() * 31) + 2;

我们大概可以得到一个规律,求 [n,m] 范围内的随机整数时,应该这样:

Math.floor(Math.random() * (m - n + 1)) + n;

那么取范围随机整数问题解决了,我们来解决那道笔试题:

let arr = new Array(5);
function randomArr(i = 0, min = 2, max = 32) {
let num = Math.floor(Math.random() * (max - min + 1)) + min;
if (!arr.includes(num)) {arr[i] = num;i++;};
return i < 5 ? randomArr(i) : arr;
};
let result = randomArr();

没超过十五行,虽然 if 这里没换行,看着不太美观,试了下,完全没问题,那么我们成功解决了这个问题。

 叁  玩点花样

既然知道了如何取范围内随机数,查了下,颜色强度范围是 [0-255] ,那么我们来做个随机变色的背景图。

function random(min = 0, max = 255) {
return Math.floor(Math.random() * (max - min + 1)) + min;
}; function randomColor() {
let r = random(),
g = random(),
b = random();
return `rgb(${r},${g},${b})`;
};
let color = randomColor();

然后,我们做出这么个东西:

 肆 

那么写到这,我们掌握了这些知识:

1.Math.random()可用来获取 [0,1) 范围的随机数,包括0但不包括1。

2.Math.floor()可对数字进行向下取整,取整规则是小于等于且最接近该数字的整数。

3.取 [n,m) 范围的随机整数通用公式

Math.floor(Math.random() * (m-n)) + n;

4.取 [n,m] 范围的随机整数通用公式

Math.floor(Math.random() * (m - n + 1)) + n;

5.如何利用取范围随机整数来获取随机颜色。

那么本文先结束,留个问题,为什么取整数不能使用round方法,或者ceil方法呢,为什么要使用floor方法?

若有兴趣,请阅读博主为何随机取整要用floor,而非ceil或round呢

js random获取随机数,获取任意范围内随机整数的更多相关文章

  1. java Math.random()生成从n到m的随机整数

    Java中Math类的random()方法可以生成[0,1)之间的随机浮点数.而double类型数据强制转换成int类型,整数部分赋值给int类型变量,小数点之后的小数部分将会丢失. 如果要生成[0, ...

  2. Java获取随机数获取制定范围指定个数不重复的随机数

    一.JDK中提供的两种方式 1.Math类中的random()方法public static double random()返回带正号的 double 值,该值大于等于 0.0 且小于 1.0 [0. ...

  3. js 为何范围内随机取整要用floor,而不是ceil或者round呢

     壹 ❀ 引 我在如何使用js取任意范围内随机整数这篇博客中,列举并分析了取[n,m)与[n,m]范围内整数的通用方法,并在文章结果留了一个疑问:为什么通用方法中取整操作,我们使用Math.floor ...

  4. java 获取随机数的三种方法

    方法1(数据类型)(最小值+Math.random()*(最大值-最小值+1))例:(int)(1+Math.random()*(10-1+1))从1到10的int型随数 方法2获得随机数for (i ...

  5. Java获取随机数的几种方法

    Java获取随机数的几种方法 .使用org.apache.commons.lang.RandomStringUtils.randomAlphanumeric()取数字字母随机10位; //取得一个3位 ...

  6. js生成[n,m]的随机数,js如何生成随机数,javascript随机数Math.random()

    一.预备知识 Math.ceil();  //向上取整. Math.floor();  //向下取整. Math.round();  //四舍五入. Math.random();  //0.0 ~ 1 ...

  7. JS random函数深入理解(转载)

    转载自:(本文对读者有帮助的话请移步支持原作者) http://www.cnblogs.com/starof/p/4988516.html 一.预备知识 Math.ceil();  //向上取整. M ...

  8. JS生成限定整数区间范围内的随机整数

    对于整数区间获取随机整数: m,n均为整数,且n>m. 获取[m,n)区间内的随机整数: 1 var aNumber = (n - m) * Math.random() + m; 2 var r ...

  9. JS中生成随机数

    1.Math 对象方法: Math.ceil(); //向上取整. Math.floor(); //向下取整. Math.round(); //四舍五入. Math.random(); //0.0 ~ ...

随机推荐

  1. C#使用拉依达准则(3σ准则)剔除异常数据(.Net剔除一组数据中的奇异值)

    原文:C#使用拉依达准则(3σ准则)剔除异常数据(.Net剔除一组数据中的奇异值) 1.问题的提出: 电池生产中,遇到一批电池的测量结果数据: 电压值 电池个数 电压值 电池个数 电压值 电池个数 电 ...

  2. 从一段简单算法题来谈二叉查找树(BST)的基础算法

    先给出一道很简单,喜闻乐见的二叉树算法题: 给出一个二叉查找树和一个目标值,如果其中有两个元素的和等于目标值则返回真,否则返回假. 例如: Input: 5 / \ 3 6 / \ \ 2 4 7 T ...

  3. 如何将编码转为自己想要的编码 -- gbk utf-8

    /**  * 数组转码  * @param array $arr 要转码的数组  * @param string $in_charset 输入的字符集  * @param string $out_ch ...

  4. ArcGIS for Desktop入门教程_第四章_入门案例分析 - ArcGIS知乎-新一代ArcGIS问答社区

    原文:ArcGIS for Desktop入门教程_第四章_入门案例分析 - ArcGIS知乎-新一代ArcGIS问答社区 1 入门案例分析 在第一章里,我们已经对ArcGIS系列软件的体系结构有了一 ...

  5. Asp +Js 无刷新分页

    Default.aspx代码 <%@ Page Language="C#" AutoEventWireup="true" CodeBehind=" ...

  6. 零元学Expression Blend 4 - Chapter 10 用实例了解布局容器系列-「StackPanel」

    原文:零元学Expression Blend 4 - Chapter 10 用实例了解布局容器系列-「StackPanel」 本系列将教大家以实做案例认识Blend 4 的布局容器,此章介绍的布局容器 ...

  7. 微信小程序把玩(三十六)Storage API

    原文:微信小程序把玩(三十六)Storage API 其实这个存储在新建Demo的时候就已经用到了就是存储就是那个logs日志,数据存储主要分为同步和异步 异步存储方法: 存数据 wx.setStor ...

  8. windows界面程序设计,设置一个窗口始终在屏幕最前,SetWindowPos函数

    有时这种需求还是很必须的,比如现在做的一个登录验证系统,如果在windows登录界面点击到窗口外面,那窗口就会永远隐藏掉没法再启用了.这种情况必须设置该窗口一直在最前. 使用函数SetWindowPo ...

  9. xen学习(一)

    添加镜像源 [root@xen xen]# cat /etc/yum.repos.d/xen.repo [xen] name=xenserver baseurl=http://mirrors.163. ...

  10. Elasticsearch教程(一)简介与安装

    简单概念 ElasticSearch是一个基于Lucene的搜索服务器.它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口.Elasticsearch是用Java开发的,并作为 ...