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

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

05.12.2018, 14:47. Показов 3915. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США. Нашел на реддите интересную статью под названием «Кто-нибудь знает, где получить бесплатный компьютер или. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru