У меня есть функция, которая помещает последовательность случайных чисел в пустой массив. Я не возражаю против дубликатов в массиве, но мне действительно нужно НЕ повторять числа, которые находятся рядом друг с другом. Так, например, [1,2,3,4,1] будет совершенно нормально, а [1,1,2,3,4] — нет. Я пытался вставить оператор if в код, но у меня не совсем получается. Вот код, который я использую для создания массива. Любая помощь, как всегда, очень благодарна!
let initArray = [];
function makeCircleArray(level) {
var i = 0;
do {
var val = Math.floor(Math.random() * 9)
initArray.push(val)
i++
}
while (i < level.dots)
console.info(`${initArray}`)
return initArray;
}
Сохраните последнее значение и повторите цикл, если вы получите то же значение:
var last_val = null;
do {
var val = Math.floor(Math.random() * 9);
if (val == last_val) continue;
initArray.push(val);
i++;
last_val = val;
} while(i < level.dots)
Вы можете сделать это, не вставляя новое значение, если оно соответствует ранее вставленному:
let initArray = [];
function makeCircleArray(level) {
var i = 0;
do {
var val = Math.floor(Math.random() * 9);
if (val !== initArray[initArray.length - 1]) {
initArray.push(val);
i++;
}
} while (i < level.dots);
console.info(`${initArray}`);
return initArray;
}
makeCircleArray({ dots: 20 });
Вам нужен особый случай для первого значения, также вы не можете увеличивать цикл, так как при обнаружении дубликата вы получите слишком мало элементов в результирующем массиве. Престижность за предоставление рабочего кода. Ты лучший мужчина, чем я :-)
Первое значение не нуждается в особом регистре (оно сравнивается с undefined
, что работает нормально). Я исправил проблему с увеличением i
слишком часто; Спасибо что подметил это!
Отменил редактирование, в результате которого был удален пояснительный текст и добавлены незначительные изменения в код. Пожалуйста, не делай этого @baymax
Включает ли ваш массив только однозначные числа или он может включать числа с большим количеством цифр?