C語言中隨機(jī)函數(shù)應(yīng)用
前言:有些程序每次執(zhí)行時(shí)不應(yīng)該產(chǎn)生相同的結(jié)果,如游戲和模擬,此時(shí)隨機(jī)數(shù)就非常有用。下面這兩個函數(shù)合在一起使用能夠產(chǎn)生偽隨機(jī)數(shù)(pseudo-random number):通過計(jì)算產(chǎn)生的隨機(jī)數(shù),可能有重復(fù)出現(xiàn),所以并不是真正的隨機(jī)數(shù)。
int rand(void);
void srand(unsigned int seed);
1>rand返回一個范圍在0和RAND_MAX(至少為32767)之間的偽隨機(jī)數(shù)。當(dāng)它重復(fù)調(diào)用時(shí),函數(shù)返回這個范圍內(nèi)其他數(shù)。為了得到一個更小范圍的偽隨機(jī)數(shù),首先把這個函數(shù)的返回值根據(jù)所需范圍的大小進(jìn)行取模,然后通過加上或減去一個偏移量對它進(jìn)行調(diào)整。
2>為了避免程序每次運(yùn)行時(shí)獲得相同的隨機(jī)數(shù)序列,可以調(diào)用srand函數(shù)。它用它的參數(shù)值對隨機(jī)數(shù)發(fā)生器進(jìn)行初始化。
一個常用的技巧是使用每天的時(shí)間作為隨機(jī)數(shù)產(chǎn)生器的種子(seed),例如:
srand((unsigned int )time(0));
2.實(shí)例:
程序一:
#include
#include
int main()
{
int k;
k=rand();
printf("%d\n", k);
return 0;
}
大家可以把以上的代碼編譯運(yùn)行一下,發(fā)現(xiàn)他的確產(chǎn)生隨機(jī)數(shù)了,但是你會發(fā)現(xiàn),每次運(yùn)行程序產(chǎn)生的隨機(jī)數(shù)都是一樣的,為什么呢?因?yàn)殡S機(jī)數(shù)取在C語言中采用的是固定序列,所以每次執(zhí)行所取的是同一個數(shù)。
那么如何寫一個程序,讓它每次運(yùn)行時(shí)產(chǎn)生的隨機(jī)數(shù)都不一樣呢? 請看下面的例子:
#include
#include
#include
Int main(void)
{
int i;
srand((unsigned int )time(0));
printf("Tenrandom numbers from 0 to 99\n\n");
for (i=0; i<10; i++)
printf("%d\n", rand()%100);
return 0;
}
這時(shí)運(yùn)行程序,會發(fā)現(xiàn)每次產(chǎn)生的隨機(jī)數(shù)都不一樣。
那么為什么第一個程序一樣而第二個程序不一樣呢?
第二個程序用到了一個新的函數(shù)srand,這個函數(shù)是給隨機(jī)數(shù)產(chǎn)生一個隨機(jī)種子(seed),函數(shù)原型是srand( (unsigned) time(NULL));
time的值每時(shí)每刻都不同。所以種子不同,所以,產(chǎn)生的隨機(jī)數(shù)也不同。
所以說,要想產(chǎn)生不同的隨機(jī)數(shù),在使用rand之前需要先調(diào)用srand
由于rand產(chǎn)生的隨機(jī)數(shù)從0到rand_max,而rand_max是一個很大的數(shù),那么如何產(chǎn)生從X~Y的數(shù)呢?
從X到Y(jié),有Y-X+1個數(shù),所以要產(chǎn)生從X到Y(jié)的數(shù),只需要這樣寫:
k=rand()%(Y-X+1)+X;
這樣,就可以產(chǎn)生你想要的任何范圍內(nèi)的隨機(jī)數(shù)了。