生成隨機數(shù)rand函數(shù)的用法詳解
更新時間:2013年05月27日 17:01:31 作者:
本篇文章是對生成隨機數(shù)rand函數(shù)的用法進行了詳細的分析介紹,需要的朋友參考下
函數(shù)rand()是真正的隨機數(shù)生成器,而srand()會設(shè)置供rand()使用的隨機數(shù)種子。如果你在第一次調(diào)用rand()之前沒有調(diào)用srand(),那么系統(tǒng)會為你自動調(diào)用srand()。而使用同種子相同的數(shù)調(diào)用 srand()會導(dǎo)致相同的隨機數(shù)序列被生成。
srand((unsigned)time(NULL))則使用系統(tǒng)定時/計數(shù)器的值做為隨機種子。每個種子對應(yīng)一組根據(jù)算法預(yù)先生成的隨機數(shù),所以,在相同的平臺環(huán)境下,不同時間產(chǎn)生的隨機數(shù)會是不同的,相應(yīng)的,若將srand(unsigned)time(NULL)改為srand(TP)(TP為任一常量),則無論何時運行、運行多少次得到的“隨機數(shù)”都會是一組固定的序列,因此srand生成的隨機數(shù)是偽隨機數(shù)。
庫函數(shù)中系統(tǒng)提供了兩個函數(shù)用于產(chǎn)生隨機數(shù):srand()和rand()。 原型為:
函數(shù)一:int rand(void);
從srand (seed)中指定的seed開始,返回一個[0, RAND_MAX(0x7fff)]間的隨機整數(shù)。
函數(shù)二:void srand(unsigned seed);
參數(shù)seed是rand()的種子,用來初始化rand()的起始值。
但是,要注意的是所謂的“偽隨機數(shù)”指的并不是假的隨機數(shù)。其實絕對的隨機數(shù)只是一種理想狀態(tài)的隨機數(shù),計算機只能生成相對的隨機數(shù)即偽隨機數(shù)。計算機生 成的偽隨機數(shù)既是隨機的又是有規(guī)律的 —— 一部份遵守一定的規(guī)律,一部份則不遵守任何規(guī)律。比如“世上沒有兩片形狀完全相同的樹葉”,這正點到了事物的特性 —— 差異性;但是每種樹的葉子都有近似的形狀,這正是事物的共性 —— 規(guī)律性。從這個角度講,我們就可以接受這樣的事實了:計算機只能產(chǎn)生偽隨機數(shù)而不是絕對的隨機數(shù)。
系統(tǒng)在調(diào)用rand()之前都會自動調(diào)用srand(),如果用戶在rand()之前曾調(diào)用過srand()給參數(shù)seed指定了一個值,那么 rand()就會將seed的值作為產(chǎn)生偽隨機數(shù)的初始值;而如果用戶在rand()前沒有調(diào)用過srand(),那么系統(tǒng)默認將1作為偽隨機數(shù)的初始 值。如果給了一個定值,那么每次rand()產(chǎn)生的隨機數(shù)序列都是一樣的~~
所以為了避免上述情況的發(fā)生我們通常用srand((unsigned)time(0))或者srand((unsigned)time(NULL))來 產(chǎn)生種子。如果仍然覺得時間間隔太小,可以在(unsigned)time(0)或者(unsigned)time(NULL)后面乘上某個合適的整數(shù)。 例如,srand((unsigned)time(NULL)*10)
另外,關(guān)于time_t time(0):time_t被定義為長整型,它返回從1970年1月1日零時零分零秒到目前為止所經(jīng)過的時間,單位為秒。
生成隨機數(shù)函數(shù)rand用法,如代碼所示:
#include "stdafx.h"
#include <time.h>
#include <stdlib.h>
int _tmain(int argc, _TCHAR* argv[])
{
// 初始化隨機數(shù)種子
// time函數(shù)返回從1970年1月1日零時零分零秒到目前為止所經(jīng)過的時間,單位為秒
srand((int)time(NULL));
int j;
for (int i = 0; i < 10; i++) {
j = (rand() * 10) / RAND_MAX + 1; // 生成1~10之間的隨機數(shù)
printf("j = %d \n", j);
}
unsigned start = (rand() * 1000)/ RAND_MAX + 15550; // 生成15550~16549之間的隨機數(shù)
printf("start = %d \n", start);
start &= ~1; // 把start變?yōu)榕紨?shù),如果是奇數(shù),則start變?yōu)閟tart - 1的偶數(shù)
printf("start = %d \n", start);
getchar();
return 0;
}
運行結(jié)果如下所示:
j = 9
j = 6
j = 7
j = 8
j = 1
j = 5
j = 3
j = 1
j = 10
j = 9
start = 16185
start = 16184
srand((unsigned)time(NULL))則使用系統(tǒng)定時/計數(shù)器的值做為隨機種子。每個種子對應(yīng)一組根據(jù)算法預(yù)先生成的隨機數(shù),所以,在相同的平臺環(huán)境下,不同時間產(chǎn)生的隨機數(shù)會是不同的,相應(yīng)的,若將srand(unsigned)time(NULL)改為srand(TP)(TP為任一常量),則無論何時運行、運行多少次得到的“隨機數(shù)”都會是一組固定的序列,因此srand生成的隨機數(shù)是偽隨機數(shù)。
庫函數(shù)中系統(tǒng)提供了兩個函數(shù)用于產(chǎn)生隨機數(shù):srand()和rand()。 原型為:
函數(shù)一:int rand(void);
從srand (seed)中指定的seed開始,返回一個[0, RAND_MAX(0x7fff)]間的隨機整數(shù)。
函數(shù)二:void srand(unsigned seed);
參數(shù)seed是rand()的種子,用來初始化rand()的起始值。
但是,要注意的是所謂的“偽隨機數(shù)”指的并不是假的隨機數(shù)。其實絕對的隨機數(shù)只是一種理想狀態(tài)的隨機數(shù),計算機只能生成相對的隨機數(shù)即偽隨機數(shù)。計算機生 成的偽隨機數(shù)既是隨機的又是有規(guī)律的 —— 一部份遵守一定的規(guī)律,一部份則不遵守任何規(guī)律。比如“世上沒有兩片形狀完全相同的樹葉”,這正點到了事物的特性 —— 差異性;但是每種樹的葉子都有近似的形狀,這正是事物的共性 —— 規(guī)律性。從這個角度講,我們就可以接受這樣的事實了:計算機只能產(chǎn)生偽隨機數(shù)而不是絕對的隨機數(shù)。
系統(tǒng)在調(diào)用rand()之前都會自動調(diào)用srand(),如果用戶在rand()之前曾調(diào)用過srand()給參數(shù)seed指定了一個值,那么 rand()就會將seed的值作為產(chǎn)生偽隨機數(shù)的初始值;而如果用戶在rand()前沒有調(diào)用過srand(),那么系統(tǒng)默認將1作為偽隨機數(shù)的初始 值。如果給了一個定值,那么每次rand()產(chǎn)生的隨機數(shù)序列都是一樣的~~
所以為了避免上述情況的發(fā)生我們通常用srand((unsigned)time(0))或者srand((unsigned)time(NULL))來 產(chǎn)生種子。如果仍然覺得時間間隔太小,可以在(unsigned)time(0)或者(unsigned)time(NULL)后面乘上某個合適的整數(shù)。 例如,srand((unsigned)time(NULL)*10)
另外,關(guān)于time_t time(0):time_t被定義為長整型,它返回從1970年1月1日零時零分零秒到目前為止所經(jīng)過的時間,單位為秒。
生成隨機數(shù)函數(shù)rand用法,如代碼所示:
復(fù)制代碼 代碼如下:
#include "stdafx.h"
#include <time.h>
#include <stdlib.h>
int _tmain(int argc, _TCHAR* argv[])
{
// 初始化隨機數(shù)種子
// time函數(shù)返回從1970年1月1日零時零分零秒到目前為止所經(jīng)過的時間,單位為秒
srand((int)time(NULL));
int j;
for (int i = 0; i < 10; i++) {
j = (rand() * 10) / RAND_MAX + 1; // 生成1~10之間的隨機數(shù)
printf("j = %d \n", j);
}
unsigned start = (rand() * 1000)/ RAND_MAX + 15550; // 生成15550~16549之間的隨機數(shù)
printf("start = %d \n", start);
start &= ~1; // 把start變?yōu)榕紨?shù),如果是奇數(shù),則start變?yōu)閟tart - 1的偶數(shù)
printf("start = %d \n", start);
getchar();
return 0;
}
運行結(jié)果如下所示:
j = 9
j = 6
j = 7
j = 8
j = 1
j = 5
j = 3
j = 1
j = 10
j = 9
start = 16185
start = 16184
相關(guān)文章
基于Matlab實現(xiàn)人工神經(jīng)網(wǎng)絡(luò)(ANN)回歸的示例詳解
這篇文章主要為大家詳細介紹了Matlab實現(xiàn)人工神經(jīng)網(wǎng)絡(luò)(ANN)回歸的相關(guān)資料,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起了解一下2023-02-02c++ 內(nèi)聯(lián)函數(shù)和普通函數(shù)的區(qū)別
內(nèi)聯(lián)函數(shù)是c++為了提高程序的運行速度做的改進,那么內(nèi)聯(lián)函數(shù)和普通函數(shù)的區(qū)別是什么,本文就來詳細的介紹一下,感興趣的朋友可以了解一下2021-05-05C++設(shè)計模式編程中簡單工廠與工廠方法模式的實例對比
這篇文章主要介紹了C++設(shè)計模式編程中簡單工廠與工廠方法模式的實例對比,文中最后對兩種模式的優(yōu)缺點總結(jié)也比較詳細,需要的朋友可以參考下2016-03-03