• js生成[n,m]的随机数


    一、预备知识 

    Math.ceil();  //向上取整。

    Math.floor();  //向下取整。

    Math.round();  //四舍五入。

    Math.random();  //0.0 ~ 1.0 之间的一个伪随机数。【包含0不包含1】 //比如0.8647578968666494

    Math.ceil(Math.random()*10);      // 获取从1到10的随机整数 ,取0的概率极小。

    Math.round(Math.random());   //可均衡获取0到1的随机整数

    Math.floor(Math.random()*10);  //可均衡获取0到9的随机整数

    Math.round(Math.random()*10);  //基本均衡获取0到10的随机整数,其中获取最小值0和最大值10的几率少一半

    因为结果在0~0.4 为0,0.5到1.4为1...8.5到9.4为9,9.5到9.9为10。所以头尾的分布区间只有其他数字的一半。

    二 、生成[n,m]的随机整数

    函数功能:生成[n,m]的随机整数。

    在js生成验证码或者随机选中一个选项时很有用。。

    //生成从minNum到maxNum的随机数
    function randomNum(minNum,maxNum){ 
        switch(arguments.length){ 
            case 1: 
                return parseInt(Math.random()*minNum+1,10); 
            break; 
            case 2: 
                return parseInt(Math.random()*(maxNum-minNum+1)+minNum,10); 
            break; 
                default: 
                    return 0; 
                break; 
        } 
    } 

     过程分析:

    Math.random()生成[0,1)的数,所以

    Math.random()*5生成{0,5)的数。

    通常期望得到整数,所以要对得到的结果处理一下。

    parseInt(),Math.floor(),Math.ceil()和Math.round()都可得到整数。

    parseInt()和Math.floor()结果都是向下取整。

    所以Math.random()*5生成的都是[0,4] 的随机整数。

    所以生成[1,max]的随机数,公式如下:

    // max - 期望的最大值
    parseInt(Math.random()*max,10)+1;
    Math.floor(Math.random()*max)+1;
    Math.ceil(Math.random()*max);

    所以生成[0,max]到任意数的随机数,公式如下:

    // max - 期望的最大值
    parseInt(Math.random()*(max+1),10);
    Math.floor(Math.random()*(max+1));

    所以希望生成[min,max]的随机数,公式如下:

    // max - 期望的最大值
    // min - 期望的最小值
    parseInt(Math.random()*(max-min+1)+min,10);
    Math.floor(Math.random()*(max-min+1)+min);

    本文作者starof,因知识本身在变化,作者也在不断学习成长,文章内容也不定时更新,为避免误导读者,方便追根溯源,请诸位转载注明出处:http://www.cnblogs.com/starof/p/4988516.html有问题欢迎与我讨论,共同进步。 

  • 相关阅读:
    [CERC2016]机棚障碍 Hangar Hurdles(kruskal重构树+树上倍增)
    jzoj4313 电话线铺设(最小生成树+最近公共祖先)
    POJ3233 Matrix Power Series(快速幂求等比矩阵和)
    【模版】分治法求平面最近点对
    [HNOI2009]最小圈 (二分答案+负环)
    [USACO]地震 (二分答案+最优比率生成树详解)
    BZOJ:1816 [Cqoi2010]扑克牌 (贪心或二分答案)
    bzoj 4184: shallot (线段树维护线性基)
    一维点距的中位数 (分治)
    [BJWC2011]最小三角形(分治+最近点对)
  • 原文地址:https://www.cnblogs.com/starof/p/4988516.html
Copyright © 2020-2023  润新知