最近想寫一個(gè)1A2B的小游戲來(lái)練習(xí)一下,結(jié)果在第一步生成隨機(jī)數(shù)的時(shí)候就遇到了一點(diǎn)點(diǎn)問(wèn)題。
游戲初始化時(shí)需要先生成一個(gè)四位隨機(jī)數(shù),且各位各不相等。于是最開(kāi)始的思路是生成一個(gè)整數(shù)數(shù)組,只需要判斷生成的隨機(jī)數(shù)字是否跟之前的數(shù)字有重復(fù),有則重新生成即可,但是之后發(fā)現(xiàn)兩個(gè)問(wèn)題。首先是,函數(shù)每次調(diào)用后生成的隨機(jī)數(shù)是一樣的。第二,生成的隨機(jī)數(shù)如果0在第一位,則調(diào)用itoa函數(shù)時(shí)會(huì)被舍棄掉。
后來(lái)研究中發(fā)現(xiàn),出現(xiàn)的原因是srand放在了函數(shù)里,每次調(diào)用函數(shù)都就重置隨機(jī)數(shù)種子至初始值,于是就會(huì)出現(xiàn)生成的隨機(jī)數(shù)都一樣的情況。至于第二種錯(cuò)誤,可以通過(guò)另一種方式來(lái)巧妙避免。代碼如下,代碼中的思路為:
先生成一個(gè)0-9的整數(shù)數(shù)組,再隨機(jī)從中取一個(gè)數(shù),只要不等于-1就將其取出放置到要生成的隨機(jī)數(shù)中,并將該位置為-1。這樣做也能提高一點(diǎn)點(diǎn)效率,而不用去刪除數(shù)組成員。
1 /****************************************************************************** 2 *函數(shù)名稱:void GetRandom(char * random) 3 *函數(shù)功能:產(chǎn)生一個(gè)各位數(shù)不相等的四位隨機(jī)數(shù) 4 *入口參數(shù):random為返回的隨機(jī)數(shù) 5 *返 回 值:無(wú) 6 *備 注:先生成一個(gè)0-9的整數(shù)數(shù)組,再隨機(jī)從中取四個(gè)數(shù),每取一個(gè)將該位置為-1 7 *******************************************************************************/ 8 void GetRandom(char * random){ 9 int i, j[10], k;10 for (i = 0; i < 10; i++){11 j[i] = i;12 }13 for(i = 0; i < 4; i++){14 //生成第i個(gè)隨機(jī)數(shù) 15 k = (int)rand() % 10;//k為下標(biāo) 16 while (j[k] == -1){17 k = (k + 1) % 10; 18 }19 random[i]