![]() |
![]() ![]() ![]() ![]() ![]() |
![]() |
Как получить неповторяющиеся случайные числа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 |