分享

随机排序

 delphi_笔记 2018-09-11
 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 TForm4.Button1Click(Sender: TObject);
var

a: array[1..10] of Integer;

i: Shortint;

begin

Randomize;
listbox1.Clear;

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;

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多