基本思路:把Math.random()生成的数看着百分比,然后定义每个整数值取值范围。

'use strict';

class GL {
/**
* 构造函数
* @param {object} opt
* @param {number} opt.min 最小整数值
* @param {number} opt.max 最大整数值
* @param {Map} opt.fenpei 自定义概率
*/
constructor({ min, max, fenpei = new Map() }) {
this.min = min;
this.max = max;
this.fenpei = fenpei;
} /**
* 可分配百分比
*/
get baifenbi() {
return (1 - this.peizhi) / (this.max - this.min - this.fenpei.size);
} /**
* 匹配百分比
*/
get peizhi() {
let result = 0;
for (let i of this.fenpei.values()) {
if (0 < i && i < 1) result += i;
}
return result;
} /**
* 随机数
* @returns {number} [min,max)
*/
random() {
let t = 0, r = Math.random();
for (let i = this.min; i < this.max; i++) {
this.fenpei.has(i) ? t += this.fenpei.get(i) : t += this.baifenbi;
if (t > r) return i;
}
return null;
}
} export default GL;
//module.exports = GL;

// 引用gl

import GL from './src/index.js';
//const GL = require('./src'); // 随机生成 1 ~ 8 之间的数(不包含8)
let gl = new GL({
min: 1,
max: 8,
fenpei: new Map([
[1, 0.1], // 1 生成概率为 10%
[2, 0.5], // 2 生成概率为 50%
[5, 0.2], // 5 生成概率为 20%
])
}); {
// 循环10000次看下概率分配情况
let map = {};
for (let i = 0; i < 10000; i++) {
let num = gl.random();
typeof map[num] !=='undefined' ? map[num] += 1 : map[num] = 0 ;
} for (let key in map) {
console.log(`${key} = ${map[key] / 10000}`);
}
}

百度网盘:

链接:https://pan.baidu.com/s/1Q8Ww3siWq9xHQ5KPPz_azQ
提取码:oyzr
复制这段内容后打开百度网盘手机App,操作更方便哦

js 控制随机数生成概率的更多相关文章

  1. js控制随机数生成概率代码实例

    基本思路:把Math.random()js随机数生成的数看着百分比,然后定义每个整数值取值范围. 具体内容如下,供大家参考 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 ...

  2. Js 控制随机数概率

    如: 取 1~10 之间的随机数,那么他们的取值范围是: 整数 区间 概率 1 [0,1) 0.1 2 [1,2) 0.1 3 [2,3) 0.1 4 [3,4) 0.1 5 [4,5) 0.1 6 ...

  3. SlimerJS – Web开发人员可编写 JS 控制的浏览器

    SlimerJS 是一个提供给 Web 开发人员,可通过脚本编程控制的浏览器.它可以让你使用 Javascript 脚本操纵一个网页:打开一个网页,点击链接,修改的内容等,这对于做功能测试,页面自动机 ...

  4. js控制Bootstrap 模态框(Modal)插件

    js控制Bootstrap 模态框(Modal)插件 http://www.cnblogs.com/zzjeny/p/5564400.html

  5. js控制文本框只能输入中文、英文、数字与指定特殊符号.

    先在'' 里输入 onkeyup="value=value.replace(/[^\X]/g,'')" 然后在(/[\X]/g,'')里的 X换成你想输入的代码就可以了, 中文u4 ...

  6. JS控制flash的方法

    JS控制flash的一些方法:Play() ---------------------------------------- 播放动画 StopPlay()---------------------- ...

  7. js 控制Div循环显示 非插件版

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  8. JS常用正则表达式和JS控制输入框输入限制(数字、汉字、字符)

    验证数字:^[0-9]*$验证n位的数字:^\d{n}$验证至少n位数字:^\d{n,}$验证m-n位的数字:^\d{m,n}$验证零和非零开头的数字:^(0|[1-9][0-9]*)$验证有两位小数 ...

  9. JS 控制CSS样式表

    JS控制CSS所使用的方法: <style> .rule{ display: none; } </style> 你想要改变把他的display属性由none改为inline.  ...

随机推荐

  1. Python练习:九九乘法表

    打印 n * n 的乘法表 #打印 9*9 乘法表 def Multiplication(n): # n - 定义打印的行数 max_len = len(str((n)**2)) #计算最大值的占位( ...

  2. SpringBoot进阶教程(二十九)整合Redis 发布订阅

    SUBSCRIBE, UNSUBSCRIBE 和 PUBLISH 实现了 发布/订阅消息范例,发送者 (publishers) 不用编程就可以向特定的接受者发送消息 (subscribers). Ra ...

  3. 目标检测之R-CNN系列

    Object Detection,在给定的图像中,找到目标图像的位置,并标注出来. 或者是,图像中有那些目标,目标的位置在那.这个目标,是限定在数据集中包含的目标种类,比如数据集中有两种目标:狗,猫. ...

  4. 补习系列(16)-springboot mongodb 数据库应用技巧

    目录 一.关于 MongoDB 二.Spring-Data-Mongo 三.整合 MongoDB CRUD A. 引入框架 B. 数据库配置 C. 数据模型 D. 数据操作 E. 自定义操作 四.高级 ...

  5. 面试官,你再问我 Bit Operation 试试?

    在面试环节中,面试官很喜欢问一些特别的题目,这些题目有着特殊的解法,如果回答的巧妙往往能在面试中加分. 在这些题目中,位操作(Bit Operation)就是极具魅力的一种.今天,吴师兄就来分享 Le ...

  6. 贾天昊 - Nick

  7. 看懂 ,学会 .NET 事件的正确姿势-简单版

    发现之前写了一篇关于事件的阐述写的过于抽象.现在想想先理解本质由简入难比较合适  之前的一篇博客地址:https://www.cnblogs.com/LiMin/p/7212217.html 参照网上 ...

  8. 设计模式 | 工厂方法模式(factory method)

    定义: 定义一个用于创建对象的接口,让子类决定实例化哪一个类.工厂方法使一个类的实例化延迟到其子类. 结构:(书中图,侵删) 一个工厂的抽象接口 若干个具体的工厂类 一个需要创建对象的抽象接口 若干个 ...

  9. 如何只在IE上加载CSS样式表

    前言:IE一直是特殊的一个浏览器,我们可以使用一些方法来指定样式表只在IE浏览器下被加载. IE9以及低于IE9版本 : 可以使用条件注释语句来加载特定于ie的样式表.如下所示,使用外部css3样式表 ...

  10. box-shadow内阴影、外阴影

    外阴影: box-shadow:X轴  Y轴  Rpx  color; 属性说明(顺序依次对应):阴影的X轴(可以使用负值) 阴影的Y轴(可以使用负值) 阴影模糊值(大小) 阴影的颜色 内阴影: bo ...