Генератор случайных чисел лото с использованием JavaScript - PullRequest
0 голосов
/ 27 октября 2018

Я очень новичок в JavaScript.В моем классе мы написали код для генератора случайных чисел, но мой не работает.Мне было интересно, если бы кто-то мог посмотреть на это и сказать мне, что я сделал неправильно.Я думаю, что мой синтаксис неверен в циклах, но не уверен.

function lottoGen() {
  var i = 0; //Variable for increment
  var d = 0; //Variable for decrement

  var arr2 = [0, 0, 0, 0, 0, 0]; //6 array values. Begin at 0

  arr2[5] = Math.random(1, 26); //Choose random number for position 5 in array

  while (i <= 4) { //Perform loop while i <= 4
    arr2[i] = Math.random(1, 69);
    d = i;
    while (d !== 0 && d <= 4) {
      d--;
      if (arr2[i] === arr2[d]) {
        i--;
      }
      i++;
    }
  }

  document.getElementById("lotto").innerHTML = arr2; //Print the array
}
<p>Lottery Number Generator</p>
<form>
  <button onclick="lottoGen()">Generate</button>
  <p id="lotto"></p>

1 Ответ

0 голосов
/ 27 октября 2018

На первой итерации i равно 0 и, следовательно, d также равно нулю, поэтому этот блок:

while (d !== 0 && d <= 4) {
  d--;
  if (arr2[i] === arr2[d]) {
    i--;
  }
  i++;
 }
}

не выполняется, так как d равно 0, поэтомуi не увеличивается, и вы попадаете в бесконечный цикл.Вы на самом деле хотите всегда шагать по массиву:

 while (i <= 4) { //Perform loop while i <= 4
  arr2[i] = Math.random(1, 69);
  d = i;
  while (d !== 0 && d <= 4) {
    d--;
    if (arr2[i] === arr2[d]) {
      i--;
    }
  }
  i++; // <<<
}

Кроме того, Math.random() не принимает никаких аргументов и возвращает число от 0 до 1, чтобы получить целое число в определенном диапазоневам придется использовать небольшую утилиту:

 const random = (min, max) => min + Math.floor((max - min) * Math.random());

console.log(random(1, 69));

PS: Если честно, ваш код на самом деле довольно сложен для понимания, а комментарии не очень полезны.Вместо того, чтобы описывать код, попробуйте описать, чего вы пытаетесь достичь:

 // Step through the array and fill it with random numbers
 while (i <= 4) { 
  arr2[i] = random(0, 69);
  d = i;
 // Check all positions to the left if the number is already taken
  while (d !== 0 && d <= 4) {
    d--;
    if (arr2[i] === arr2[d]) {
      // If thats the case, stay at this position and genrate a new number
      i--;
    }
  }
  i++;
}

Как бы я написал это:

 function lottoGen() {
   const result = [];

  for(let count = 0; count < 6; count++) {
    let rand;
    do {
      rand = random(0, 69);
    } while(result.includes(random))
    result.push(rand);
  }

  return result;
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...