javascript – 如何有效地随机选择数组项而不重复?

前端之家收集整理的这篇文章主要介绍了javascript – 如何有效地随机选择数组项而不重复?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我知道这个问题在许多方面存在,但我无法找到与我的具体效率问题相关的答案.

我有下面的代码,工作得很好.

我有一个10项数组,我从中随机选择一个项目(按下输入键).代码保留了最近5个选项的数组,这些选择不能随机选择(以避免随着时间的推移重复过多).

如果chooseName()函数最初选择在最近的5中使用的名称,它只会断开并再次调用自身,重复直到找到“唯一”名称.

我有两个问题:

>说这是一个“递归函数”是否正确?
>我担心理论上这可能会在找到一个唯一名称之前保持循环很长时间 – 是否有更有效的方法来执行此操作?

感谢您的任何帮助.

var a = ["Roger","Russell","Clyde","Egbert","Clare","Bobbie","Simon","Elizabeth","Ted","Caroline"];
    var b = [];

    var chooseName = function () {
    var unique = true;
    b.length = 5;
    num = Math.floor(Math.random() * a.length);
    name = a[num];    
        for (i = 0; i < a.length; i++) {
        if (b[i] == name) {
            chooseName();
            unique = false;
            break;
            }
        }
        if (unique == true) {
        alert(name);
        b.unshift(name);
        }
    }


    window.addEventListener("keypress",function (e) {
        var keycode = e.keyCode;
        if (keycode == 13) {
        chooseName();
        }
    },false);

解决方法

每当选择一个项目时,将其移动到数组的后面,并从原始数组array.slice(0,-5)的切片中随机选择.
var a = ["Roger","Caroline"];

var chooseName = function () {
    var unique = true;
    num = Math.floor(Math.random() * a.length - 5);
    name = a.splice(num,1);
    a.push(name);
}


window.addEventListener("keypress",function (e) {
    var keycode = e.keyCode;
    if (keycode == 13) {
        chooseName();
    }
},false);

编辑:这也有副作用,即不给出任何变量发生在列表中的不公平的缺点,即在前N个调用中不会考虑它们.如果这对您来说是个问题,可以尝试在某处保持一个静态变量来跟踪要使用的切片的大小,并在B处最大化(在本例中为5).
例如

var a = ["Roger","Caroline"];
B = 5; //max size of 'cache'
N = 0;

var chooseName = function () {
    var unique = true;
    num = Math.floor(Math.random() * a.length - N);
    N = Math.min(N + 1,B);
    name = a.splice(num,1);
    a.push(name);
}

猜你在找的JavaScript相关文章