全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:1157
推到 Plurk!
推到 Facebook!

数字随机排序问题?

答題得分者是:william
sos_admin
版主


發表:121
回覆:697
積分:768
註冊:2003-07-23

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-12-17 11:39:16 IP:61.155.xxx.xxx 未訂閱
小弟最近在一个项目中遇到这样一个问题: (开发语言vb) 假设有一组数字 1~1000 请将它们随机填充在一个数组中 dim mysz(1000) as integer 要求: 1、数组中无重复数字 2、整个程式运算很快,要求在10秒内完成! 我用vb做成的,但是只要随机数个数>15,速度奇慢! 各位如果有什么好的方法(程式语言任意),请指教!
william
版主


發表:66
回覆:2535
積分:3048
註冊:2002-07-11

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-12-17 11:56:26 IP:147.8.xxx.xxx 未訂閱
VB  > < class="code">var Nums: array[1..1000] of integer; i,j,k,temp: integer; begin for i := Low(Nums) to High(Nums) do Nums[i] := i; for i := 0 to 1000 do begin // 1001 round may not be enough j := random(High(Nums)) 1; k := random(High(Nums)) 1; temp := Nums[j]; Nums[j] := Nums[k]; Nums[k] := temp; end; end;
Fishman
尊榮會員


發表:120
回覆:1949
積分:2163
註冊:2006-10-28

發送簡訊給我
#3 引用回覆 回覆 發表時間:2003-12-17 12:47:37 IP:210.65.xxx.xxx 未訂閱
Hi:    我有一些新的想法,與大家共同分享、討論    
procedure TForm1.Button11Click(Sender: TObject);
VAR
    I,R : Integer;
    S : TStrings;
begin
    ListBox1.Items.Clear;
    for i := 1 to 1000 do
        begin
            ListBox1.Items.Add(IntToStr(I));
        end;
    S := TStringList.Create;
    S.Assign(ListBox1.Items);
    ListBox2.Items.Clear;
    FOR I := 1000 DOWNTO 1 DO
        BEGIN
            R := Random(I)   1;
            ListBox2.Items.Add(S.Strings[R - 1]);
            S.Delete(R - 1);
        END;
    S.Free;
end;
在此我用ListBox 來代替 Array,以方便直接觀看執行結果 -------------------------------- 小弟才疏學淺,若有謬誤請不吝指教 --------------------------------
------
Fishman
系統時間:2024-07-01 23:56:42
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!