Форум программистов, компьютерный форум, киберфорум
JavaScript
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/18: Рейтинг темы: голосов - 18, средняя оценка - 4.83
0 / 0 / 0
Регистрация: 05.12.2018
Сообщений: 3

Как перемешать массив случайным образом без повторений на чистом JavaScript?

05.12.2018, 14:47. Показов 3957. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. Я о программировании не имею не малейшего понятия, поэтому сильно не пинайте. На досуге пару недель читал об HTML, СSS, пару недель почитал о JavaScript и решил для себя сделать что то на подобие тестовых вопросов.
Выглядит как то так:
HTML5
1
2
3
4
5
6
7
<div id="question1" style="display:none"><h1>Вопрос№1</h1></div>
<div id="question2" style="display:none"><h1>Вопрос№2</h1></div>
<div id="question3" style="display:none"><h1>Вопрос№3</h1></div>
<div id="question4" style="display:none"><h1>Вопрос№4</h1></div>
<div id="question_N" style="display:none"><h1>Вопрос№N</h1></div>
 
<input type="button" value="Следующий" onclick="next()">
Сейчас использую такую функцию:
JavaScript
1
2
3
4
5
6
7
8
next_q = new Array();
    next_q[0]=document. getElementById ("question1");
    next_q[1]=document. getElementById ("question2");
    next_q[2]=document. getElementById ("question3");
    next_q[3]=document. getElementById ("question4");
    next_q[N]=document. getElementById (question_N");
var m = Math.round(Math.random()*45);
next_q[m].style.display="block";
Это работает, но вопросы повторяются.

Какой скрипт даст возможность каждый раз показывать вопросы в разном порядке?

Я уже неделю пытаюсь сам понять как это сделать, но ничего не получается. Толи нужен еще один массив, который будет хранить уже выпавшие числа, а потом как то взаимодействовать с массивом с вопросами? Так же читал о shuffle, посмотрел сотню примеров. Кажется наиболее подходящая вещь,
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
Array.prototype.shuffle = function( b )
{
 var i = this.length, j, t;
 while( i ) 
 {
  j = Math.floor( ( i-- ) * Math.random() );
  t = b && typeof this[i].shuffle!=='undefined' ? this[i].shuffle() : this[i];
  this[i] = this[j];
  this[j] = t;
 }
 return this;
};
или это:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
Array.prototype.shuffle = function() {
    return this.sort(function() {
        return 0.5 - Math.random();
    });
};
 
var N = 10000, a = [], i;
for (i = 0; i < 10; i++) {
    a[i] = 0;
}
for (i = 0; i < N; i++) {
    a[[0, 1, 2, 3, 4, 5, 6, 7, 8, 9].shuffle()[0]]++;
}
alert(a);
но не понимаю как соединить свой массив с этим shuffle.

Граждане программисты, напишите, пожалуйста, код и, если можно, вкратце как оно работает
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
05.12.2018, 14:47
Ответы с готовыми решениями:

Перемешать массив случайным образом
Помогите кто может... необходимо логически код разбить на функции( ну это понятно) и вот само условие: Перемешать массив а(n) случайным...

Перемешать случайным образом массив целых чисел
Здравствуйте! Подскажите, пожалуйста, как в C# перемешать случайным образом массив целых чисел. Аналог random.shuffle(lst) в Python. ...

Перемешать элементы массива случайным образом
Добрые люди! Помогите бедному человеку решить казалось бы простую задачку... Есть текстовой файл в нем скажем 10 строк, надо, что бы...

5
566 / 465 / 183
Регистрация: 14.10.2017
Сообщений: 1,259
05.12.2018, 15:41
можно так
HTML5
1
2
<button id="nxt">Next</button>
<p id="testQuestion"></p>
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
function shakeUp(size){
    let arr = new Array(size).fill(0).map((el, i) => i);
    for(let i = arr.length - 1; i > 0; i--){
        let j = Math.floor(Math.random() * i);
        let tmp = arr[i];
        arr[i] = arr[j];
        arr[j] = tmp;
    }
    return arr;
}
let testQuestion = document.getElementById('testQuestion');
let questions = ['Вопрос 1','Вопрос 2','Вопрос 3','Вопрос 4','Вопрос 5'];
let shufArr = shakeUp(questions.length);
let nxt = document.getElementById('nxt');
let x = 0;
const flippingQuestions = () => {
    if(x >= questions.length)
        return false;
    testQuestion.innerText = questions[shufArr[x++]];
}
nxt.addEventListener('click', flippingQuestions);
1
0 / 0 / 0
Регистрация: 05.12.2018
Сообщений: 3
05.12.2018, 20:13  [ТС]
Спасибо вам за труды. Не могу понять как применить данное Вами решение в своем случае. Или вообще ничего не происходит, или ничего не происходит, но с ошибкой "cannot read property 'addEventListener' of null". Правильно ли я понял, при клике на кнопку, nxt.addEventListener присваивает константе flippingQuestions номер случайного "дива"? А метод innerText должен этот "див" делать видимым? А как сработает функция shakeUp(size), её же ничего не запускает?
Видимо самостоятельно мне не освоить решение этой проблемы, очень сложно для восприятия без хорошего знания теории, впрочем как в любом деле.

И если Вам не сложно, напишите решение JS конкретно под этот вариант, может мне будет легче понять:
HTML5
1
2
3
4
5
6
7
<div id="question1" style="display:none"><h1>Вопрос№1</h1></div>
<div id="question2" style="display:none"><h1>Вопрос№2</h1></div>
<div id="question3" style="display:none"><h1>Вопрос№3</h1></div>
<div id="question4" style="display:none"><h1>Вопрос№4</h1></div>
 
 
<input type="button" value="Следующий" onclick="next()">
0
566 / 465 / 183
Регистрация: 14.10.2017
Сообщений: 1,259
05.12.2018, 20:41
Цитата Сообщение от 100563 Посмотреть сообщение
но с ошибкой "cannot read property 'addEventListener' of null"
мой код заточен под мой HTML, который я опубликовал, на вашем он не будет работать. Я просто сделал проще.
Цитата Сообщение от 100563 Посмотреть сообщение
константе flippingQuestions
это функция, просто синтаксис ES6, наверное вы еще не знаете.
Цитата Сообщение от 100563 Посмотреть сообщение
А метод innerText должен этот "див" делать видимым?
Нет. Вот здесь почитайте про innerText
Цитата Сообщение от 100563 Посмотреть сообщение
А как сработает функция shakeUp(size), её же ничего не запускает?
Как это не запускает? А в строке 13? Функция shakeUp возвращает массив, заполненный индексами этого же массива в случайном порядке и записывается он в переменную shufArr. Теперь их можно использовать в качестве индексов массива с вопросами, чтобы выводить по одному вопросу на каждый клик кнопки, и вопросы не будут повторяться.
Цитата Сообщение от 100563 Посмотреть сообщение
Видимо самостоятельно мне не освоить решение этой проблемы, очень сложно для восприятия без хорошего знания теории
глядя на ваш
JavaScript
1
Array.prototype.shuffle
я было подумал что вы уже продвинулись неплохо
песочница
1
0 / 0 / 0
Регистрация: 05.12.2018
Сообщений: 3
06.12.2018, 14:35  [ТС]
Спасибо. 3 часа мучений и заработало. Очень помогло, что написали в "песочнице". Практически сразу понял что к чему и что кого запускает. Остальное время пытался приспособить к своему HTML. Большое спасибо
0
566 / 465 / 183
Регистрация: 14.10.2017
Сообщений: 1,259
06.12.2018, 15:22
Цитата Сообщение от 100563 Посмотреть сообщение
Очень помогло, что написали в "песочнице".
в песочнице тот же самый код что и здесь, буква в букву.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
06.12.2018, 15:22
Помогаю со студенческими работами здесь

Перемешать случайным образом компоненты вектора
Дан вектор, нужно перемешать случайным образом его компоненты. Как-то идут мысли в сторону использования rnd, но ничего хорошего не...

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

Дана строчка (с любым текстом), нужно перемешать в ней все слова случайным образом
Дана строчка (с любым текстом), нужно перемешать в ней все слова случайным образом, учитывая разделители? напр. vhodstr:='раз,...

Pascal!? Дана строчка (с любым текстом), нужно перемешать в ней все слова случайным образом?
Pascal!? Дана строчка (с любым текстом), нужно перемешать в ней все слова случайным образом, учитывая разделители? напр. ...

Строки и множества. Случайным образом заполнить множество рабочих дней в цикле из 6 повторений
Строки и множества. Случайным образом заполнить множество рабочих дней в цикле из 6 повторений.


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru