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

伊莉討論區

搜索
尊貴會員無限觀看附件圖片尊貴會員無限看帖不用回覆你準備好成為出色的版主了嗎?
火影忍者國中蘿莉人妻柯南中文安卓
桌布女援交jk陽依のサ涼墨(hot sum拜托了離婚後霍

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

[繁]我要【招架】一切

睪丸被蛇咬 怒拿馬桶

[繁]我要【招架】一切

[繁]新人大叔冒險者,

[繁]杖與劍的魔劍譚08

[繁]靠廢柴技能【狀態
C & C++ 語言C# 語言Visual Basic 語言PHP 語言JAVA 語言
查看: 1191|回復: 7
打印上一主題下一主題

[問題]請問如何讓每次出現的數字都不重複?[複製鏈接]

ycess87009 該用戶已被刪除
跳轉到指定樓層
樓主
發表於 2011-12-25 11:26 AM|只看該作者|倒序瀏覽
如果我建立1個36萬筆的資料,而我想要把數據的順序給打亂,而且每次執行的順序都不一樣。

所以我先想測試如何產生不同的num_random陣列。

於是我這樣寫:
下載: 訪客無法瀏覽下載點,請先 註冊登入會員



可是,如果把下面程式中的"360000"改成5的話
...
瀏覽完整內容,請先 註冊登入會員
分享分享0收藏收藏0支持支持0
回覆中加入附件並不會使你增加積分,請使用主題方式發佈附件。

使用道具檢舉

Rank: 2Rank: 2

帖子
65
積分
231 點
潛水值
23520 米
頭香
發表於 2011-12-25 04:17 PM|只看該作者
回復
下載: 訪客無法瀏覽下載點,請先 註冊登入會員
ycess87009



rand() % 360000 是整數亂數取出之後除以360000後得到的餘數, 那如果rand() % 5 就是只有可能是0, 1, 2, 3, 4. 那原PO的for loop 是做360000次, 那可能會有三十幾萬個數據會重複. 希望我沒有理解錯原PO的問題....
瀏覽完整內容,請先 註冊登入會員

使用道具檢舉

刃丑 該用戶已被刪除
3
發表於 2011-12-25 11:56 PM|只看該作者
簡單,只要把已產生資料存下來,一個個比較

使用道具檢舉

runeray2000 該用戶已被刪除
4
發表於 2011-12-26 12:17 AM|只看該作者
%5  的話,只有0 1 2 3 4
5種數字,在36000個變數裡怎麼可能不重複,
如果是要產生36000 數字不重複的陣列我這邊有兩個方法給你參考
1: 每產生一個亂數就一一比對之前有沒有出現過,沒有才填入,否則再重新產生一個再重新比對之前的。(此方法亂數的範圍一定要大於36000,大越多越好,否則會無限迴圈)
2: 先產生1 2 3 .....360000 的數字陣列,再用亂數%360000產生隨機交換兩筆資料位址,重複隨機交換的次數越多資料就越亂,我的習慣是重複約  360000*5 次。...
瀏覽完整內容,請先 註冊登入會員
分享使你變得更實在,可以使其他人感到快樂,分享是我們的動力。今天就來分享你的資訊、圖片或檔案吧。

使用道具檢舉

Rank: 3Rank: 3Rank: 3

帖子
479
積分
1759 點
潛水值
33422 米
5
發表於 2011-12-26 03:51 AM|只看該作者
若新密碼無法使用,可能是數據未更新。請使用舊密碼看看。
承接樓上,這種寫法大致如下:
  1. #define N (360000)
  2. int array[N];
  3. for(int i=0;i<N;i++)
  4.      array[i]=i+1; // 先產生 1~360000
  5. srand(time(NULL));
  6. for(int i=N-1,j;i>0;i--){
  7.      j=rand()%(i+1);
  8.      swap(array[i],array[j]);
  9.      }
複製代碼
...
瀏覽完整內容,請先 註冊登入會員





使用道具檢舉

android123 該用戶已被刪除
6
發表於 2011-12-26 10:40 AM|只看該作者
4樓的方法二不錯,這問題有點像是CD PLAYER的亂數播放,還有一個方法是先依照順序列出1~360000,然後就像擲骰子一樣取得一個亂數當成是前進的步數,例如60表示這一步往後走60就是你的下一個數字,走過的值劃上記號下次不要再走,這樣走了360000次後就得到不重複的排列。
若有安裝色情守門員,可用無界、自由門等軟件瀏覽伊莉。或使用以下網址瀏覽伊莉: http://www.eyny.com:81/index.php

使用道具檢舉

Rank: 5Rank: 5Rank: 5Rank: 5Rank: 5

帖子
2979
積分
12825 點
潛水值
41478 米
7
發表於 2011-12-26 11:24 AM|只看該作者
分享使你變得更實在,可以使其他人感到快樂,分享是我們的動力。今天就來分享你的資訊、圖片或檔案吧。
本帖最後由 goodbye_mylove 於 2011-12-26 11:25 AM 編輯

回復
下載: 訪客無法瀏覽下載點,請先 註冊登入會員
runeray2000


重複隨機交換的次數越多資料就越亂。


這結論是錯的。
關於 shuffle 目前網路上都是隨便說說而已,shuffle 細節也有人提出了 7, 8 種,
...
瀏覽完整內容,請先 註冊登入會員
如果我說,灌了二頁的水是因為lag / 系統不穩,
我想應該也不會有人相信吧..
所有積分大於負-100的壞孩子,將可獲得重新機會成為懲罰生,權限跟幼兒生一樣。

使用道具檢舉

runeray2000 該用戶已被刪除
8
發表於 2011-12-27 09:15 PM|只看該作者
感謝 5 樓 , 6樓 , 和7樓版大指教喔~
學到新招了~  ^o^
成為伊莉的版主,你將獲得更高級和無限的權限。把你感興趣的版面一步步地發展和豐盛,那種滿足感等著你來嚐嚐喔。

使用道具檢舉

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

Powered by Discuz!

© Comsenz Inc.

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