找回密碼 或 安全提問
 註冊
|註冊|登錄

伊莉討論區

搜索
請尊重及感激所有版主付出和奉獻尊貴會員無限使用任何功能搞笑、娛樂、精彩的影片讓你看
人妻rion鬼父新竹銀魂世紀帝國
論渣男改gods calセリカマ3d惡靈古堡なしぱす幼冴

休閒聊天興趣交流學術文化旅遊交流飲食交流家庭事務PC GAMETV GAME
熱門線上其他線上感情感性寵物交流家族門派動漫交流貼圖分享BL/GL
音樂世界影視娛樂女性頻道潮流資訊BT下載區GB下載區下載分享短片
電腦資訊數碼產品手機交流交易廣場網站事務長篇小說體育運動時事經濟
上班一族博彩娛樂

[超清繁中]霹靂英雄戰

(4月新番)[繁]狼與辛

[繁]格林童話變奏曲02

✡ 斗破蒼穹 年番/鬥

[簡]單人房、日照一般

[繁]Re:Monster 04-
C & C++ 語言C# 語言Visual Basic 語言PHP 語言JAVA 語言
查看: 7216|回復: 1
打印上一主題下一主題

[求助]請問如何能讓程式出來的數字不重複到(樂透號碼)[複製鏈接]

Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6

帖子
855
積分
-6 點
潛水值
55969 米
樓主
發表於 2012-12-23 04:19 AM|顯示全部樓層
若新密碼無法使用,可能是數據未更新。請使用舊密碼看看。
arthurliuliu 發表於 2010-11-3 08:01 AM
下載: 訪客無法瀏覽下載點,請先 註冊登入會員

有一種效能比較好的作法, 若是取七個亂數:
1.建立一個array, 然後按照順序把 ar[0]~ar[48] 填上 1~49
2.從a ...

想問一下這個方式 機率上是不是會有問題?
...
瀏覽完整內容,請先 註冊登入會員
成為伊莉的版主,你將獲得更高級和無限的權限。把你感興趣的版面一步步地發展和豐盛,那種滿足感等著你來嚐嚐喔。

使用道具檢舉

Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6

帖子
855
積分
-6 點
潛水值
55969 米
頭香
發表於 2012-12-24 06:08 PM|顯示全部樓層
本帖最後由 jack810216 於 2012-12-24 06:18 PM 編輯
  1.     Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
  2.         Label1.Text = ""
  3.         Dim rnd As New Random
  4.         Dim t(50) As Byte
  5.         Dim sum(50) As Long
  6.         Dim rnd_tmp As Byte
  7.         Dim tmp As Byte
  8.         For k = 1 To 10000
  9.             For n = 1 To 50
  10.                 t(n) = n
  11.             Next
  12.             For n = 1 To 7
  13.                 rnd_tmp = rnd.Next(1, 51)
  14.                 tmp = t(n)
  15.                 t(n) = t(rnd_tmp)
  16.                 t(rnd_tmp) = tmp
  17.             Next

  18.             For n = 1 To 7
  19.                 sum(t(n)) += 1
  20.             Next
  21.         Next
  22.         For n = 1 To 50
  23.             Label1.Text &= n & " : " & sum(n) & vbNewLine
  24.         Next
  25.     End Sub
複製代碼
  1.     Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
  2.         Label1.Text = ""
  3.         Dim rnd As New Random
  4.         Dim t(50) As Byte
  5.         Dim sum(50) As Long
  6.         Dim tmp As Byte
  7.         Dim x As Byte
  8.         For i = 1 To 10000
  9.             x = 0
  10.             For n = 1 To 50
  11.                 t(n) = n
  12.             Next
  13.             While x < 7
  14.                 tmp = rnd.Next(1, 51)
  15.                 If t(tmp) <> 0 Then
  16.                     t(tmp) = 0
  17.                     sum(tmp) += 1
  18.                     x += 1
  19.                 End If
  20.             End While
  21.         Next
  22.         For n = 1 To 50
  23.             Label1.Text &= n & " : " & sum(n) & vbNewLine
  24.         Next
  25.     End Sub
複製代碼
上面的應該是板主說的方法吧?
會有明顯的機率差
下面的是普通的方法就不會
我想是交換的問題吧

試了一下 改成這樣就沒問題了...
  1. rnd_tmp = rnd.Next(n, 51)
複製代碼
...
瀏覽完整內容,請先 註冊登入會員
回覆中加入附件並不會使你增加積分,請使用主題方式發佈附件。

使用道具檢舉

您需要登錄後才可以回帖 登錄 | 註冊

Powered by Discuz!

© Comsenz Inc.

重要聲明:本討論區是以即時上載留言的方式運作,對所有留言的真實性、完整性及立場等,不負任何法律責任。而一切留言之言論只代表留言者個人意見,並非本網站之立場,用戶不應信賴內容,並應自行判斷內容之真實性。於有關情形下,用戶應尋求專業意見(如涉及醫療、法律或投資等問題)。 由於本討論區受到「即時上載留言」運作方式所規限,故不能完全監察所有留言,若讀者發現有留言出現問題,請聯絡我們。有權刪除任何留言及拒絕任何人士上載留言,同時亦有不刪除留言的權利。切勿上傳和撰寫 侵犯版權(未經授權)、粗言穢語、誹謗、渲染色情暴力或人身攻擊的言論,敬請自律。本網站保留一切法律權利。
回頂部