Последние записи
- Перенести программу из Delphi в Lazarus
- Определить текущую ОС
- Автоматическая смена языка (раскладки клавиатуры)
- Сравнение языков на массивах. Часть 2
- wprintf как напечатать кириллицу
- Взаимодействие через командную строку
- Сравнение языков на массивах. Часть 1
- Сравнение языков по скорости
- Чтение огромных xml-файлов
- Как в Python+Selenium webdriver открыть новую вкладку в уже открытом браузере?
Интенсив по Python: Работа с API и фреймворками 24-26 ИЮНЯ 2022. Знаете Python, но хотите расширить свои навыки?
Slurm подготовили для вас особенный продукт! Оставить заявку по ссылке - https://slurm.club/3MeqNEk
Online-курс Java с оплатой после трудоустройства. Каждый выпускник получает предложение о работе
И зарплату на 30% выше ожидаемой, подробнее на сайте академии, ссылка - ttps://clck.ru/fCrQw
20th
Окт
Выбор случайных вопросов без повторений
Posted by obzor under Delphi
К примеру есть 57 вопросов из которых должны отобразится всего 15 у пользователя на экране.
Каждый следующий вопрос должен появляться при нажатии кнопки.
Но как показала практика из за генерации случайных чисел вопросы могут выпадать по два раза подряд одни и те же. Или за все время прохождения теста.
Вопрос, как сделать проверку чисел чтобы не выводить значения которые уже были?
Можно, например, в TList поместить номера вопросов, рандомно выбирать и удалять после выбора. Аналогично это можно сделать с массивом номеров.
Легко, красиво и изящно используя Set
VAR
L: Set of 1..57 ;
R: Byte;
I: Integer;
Begin
Randomize;
For i:= 1 to 15 Do
Begin
Repeat
R:= Random(57) + 1;
Until Not (R in L);
L:= L + [R]
End;
For I:= 1 to 57 Do
If I in L Then WriteLn(I);
End.
в таких задачах намного удобнее просто заполнить массив(список) значениями подряд и потом перемешать случайным образом: ТЫЦ
например,
const N = 57;
var
i,k,buf:integer;
mas: array [1..N] of integer;
begin
//заполнить
for i:=1 to N do mas:=i;
Randomize;
//----------перемешать-------------
for i:=1 to N-1 do
begin
k:= Random(N-i+1)+i;
if k<>i then begin
buf:=mas;
mas:=mas[k];
mas[k]:=buf;
end;
end;
//-------------вывести-------------
for i:=1 to N do Write(mas:3);
end;
Похожие статьи
Купить рекламу на сайте за 1000 руб
пишите сюда - alarforum@yandex.ru
Да и по любым другим вопросам пишите на почту
пеллетные котлы
Пеллетный котел Emtas
Наши форумы по программированию:
- Форум Web программирование (веб)
- Delphi форумы
- Форумы C (Си)
- Форум .NET Frameworks (точка нет фреймворки)
- Форум Java (джава)
- Форум низкоуровневое программирование
- Форум VBA (вба)
- Форум OpenGL
- Форум DirectX
- Форум CAD проектирование
- Форум по операционным системам
- Форум Software (Софт)
- Форум Hardware (Компьютерное железо)