![]() |
![]() ![]() ![]() ![]() |
|
Как получить неповторяющиеся случайные числаDelphi , Синтаксис , МатематикаАвтор: http://www.swissdelphicenter.ch
procedure Shuffle(var aArray; aItemCount: Integer; aItemSize: Integer);
{ after Julian M Bucknall }
var
Inx: Integer;
RandInx: Integer;
SwapItem: PByteArray;
A: TByteArray absolute aArray;
begin
if (aItemCount > 1) then
begin
GetMem(SwapItem, aItemSize);
try
for Inx := 0 to (aItemCount - 2) do
begin
RandInx := Random(aItemCount - Inx);
Move(A[Inx * aItemSize], SwapItem^, aItemSize);
Move(A[RandInx * aItemSize], A[Inx * aItemSize], aItemSize);
Move(SwapItem^, A[RandInx * aItemSize], aItemSize);
end;
finally
FreeMem(SwapItem, aItemSize);
end;
end;
end;
procedure TForm1.Button1Click(Sender: TObject);
var
a: array[1..10] of Integer;
i: Shortint;
begin
Randomize;
for i := Low(a) to High(a) do
a[i] := i;
Shuffle(a, High(a), SizeOf(Integer));
for i := 1 to High(a) - 1 do
ListBox1.Items.Add(IntToStr(a[i]));
end;
Переведенный текст: Код - это программный проект на языке Delphi, который реализует алгоритм Fisher-Yates shuffle, широко используемый для генерации случайной перестановки конечного последовательности. Процедура Рассмотрим, как работает код:
Процедура
Чтобы получить не повторяющиеся случайные числа, можно использовать этот алгоритм в сочетании с хранением генерируемых случайных чисел в множестве или коллекции, которая отслеживает уникальные элементы. Вот пример: В этом примере мы создаем пустую коллекцию Обратите внимание, что это реализация имеет ограничения при генерации случайных чисел для большого диапазона или для маленького диапазона с высокой точностью. В таких случаях может потребоваться использование болееadvanced алгоритмов или библиотек. В статье описывается алгоритм получения неповторяющихся случайных чисел в программировании на языке Delphi, реализуемый с помощью процедуры Shuffle, которая использует алгоритм Фишера-Йатса. Комментарии и вопросыПолучайте свежие новости и обновления по Object Pascal, Delphi и Lazarus прямо в свой смартфон. Подпишитесь на наш :: Главная :: Математика ::
|
||||
©KANSoftWare (разработка программного обеспечения, создание программ, создание интерактивных сайтов), 2007 | ||||