循环逻辑

时间:2013-02-19 07:58:32

标签: javascript

我正在使用javascript函数,其中循环应该运行10次,在这10次中,它应该抛出基于,+和 - 操作的随机问题,因为它也应该有4个“+”问题,3“ - ”问题和3“”问题。并且循环不应该运行超过10次,有人请为此构建逻辑...

到目前为止我的代码:

<script type="text/javascript">
        var op=new Array();
        var addCount=0;
        var subCount=0;
        var mulCount=0;
        var counter=0;
        var no;
        op[0]="+";
        op[1]="-";
        op[2]="x";

        Array.prototype.chooseRandom = function() 
        {
            return this[Math.floor(Math.random() * this.length)];
        };
        var a = [1, 2];
        var b = [0, 2];
        var c = [0, 1];

            no=Math.floor((Math.random()*3));
            while(addCount < 4|| subCount < 3 || mulCount < 3)
            {

                    no=Math.floor((Math.random()*3));
                    if(no==0)
                    {
                        if(addCount<4)
                        {
                            addCount++;
            var op1=Math.floor(Math.random() * (99 - 10+1)) + 10;
                var op2=Math.floor(Math.random() * (99 - 10+1)) + 10;
                        }
                        else
                        {
                            no=a.chooseRandom();
                        }
                    }       
                    else if(no==1)
                    {
                        if(subCount<3)
                        {
                            subCount++;
            var no1=Math.floor(Math.random() * (99 - 10+1)) + 10;
            var no2=Math.floor(Math.random() * (99 - 10+1)) + 10;
                            if(no1>no2)
                            {
                                 var op1=no1;
                                 var op2=no2;
                            }
                            else
                            {
                                var op1=no2;
                                var op2=no1;
                            }
                        }
                        else
                        {
                            no=b.chooseRandom();
                        }
                    }
                    else if(no==2)
                    {
                        if(mulCount<3)
                        {
                            mulCount++;
            var op1=Math.floor(Math.random() * (99 - 10+1)) + 10;
            var op2=Math.floor(Math.random() * (9 - 1+1)) + 1;
                        }
                        else
                        {
                            no=c.choseRandom();
                        }
                    }

                    counter++;
            }
    </script>

2 个答案:

答案 0 :(得分:0)

制作一个包含所需数量+-*的数组,然后使用下面的函数随机排序:

arr.sort(function() {return 0.5 - Math.random()})

答案 1 :(得分:0)

希望它会有所帮助 -

<script type="text/javascript">
    function shuffle(o) {
        for (var j, x, i = o.length; i; j = parseInt(Math.random() * i), x = o[--i], o[i] = o[j], o[j] = x);
        return o;
    }

    function getQuestions(){
        var operators = shuffle(["+", "+", "+", "+", "-", "-", "-", "x", "x", "x"]);
        var a = [1, 2, 3, 4, 5, 6];
        var counter = 0;

        Array.prototype.chooseRandom = function () {
            return this[Math.floor(Math.random() * this.length)];
        };

        while (counter < 10) {
            var op1 = a.chooseRandom();
            var op2 = a.chooseRandom();
            alert(op1 + operators[counter] + op2 + "?")
            counter++;
        }
    }

    getQuestions();
</script>