js 随机获取10个不重复的1~20之间的整数数组

要想用js随机获取10个1~20之间的整数组成一个数组,这并不困难,但是这样获取出来的数字难免会有重复的,那么如何获取出一个不重复的数组呢。

js代码如下:

<body>
    <p id="pid">p>
    <script>
        var pid = document.getElementById('pid');
        var arr = [];
        for(var i=0;i<10;i++){
            getx(arr);
        }

        function getx(arr){
            for(var i=0;i>-1;i++){
                var flag = true;
                var num = Math.floor(Math.random()*20)+1;
                for(var i in arr){
                    if(arr[i] == num){
                        flag= false;
                        break;
                    }
                }
                if(flag == true){
                    console.log(num);
                    arr.push(num);
                    return;
                }
            }
        }

        pid.innerHTML = arr;

    script>

思路如下:
我们封装一个函数,这个函数用来返回一个随机数。
首先,我们先来写一个死循环,在函数开始的时候设置一个flag,并且生成一个随机数,然后遍历一下数组,如果数组中已经存在这个随机数了,就把flag变成false,并且跳出遍历。跳出遍历或者等遍历完成之后判断一下flag的值,如果flag为true,就把这个数push进数组,并且return然后中断死循环,跳出循环,否则的话继续运行这个循环,直到得到一个数组中不存在的数字为止。

其实要实现这个功能有很多种思路啊,这只是博主自己一个人的思路,大家可以集思广益哦,肯定会有很大的收获

你可能感兴趣的:(javascript)