我正在使用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>
答案 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>