#include
網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)!專注于網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、小程序開發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了疊彩免費(fèi)建站歡迎大家使用!
#include
#include
intmain()
{
inti,j,n,k,t,a[100];
srand((unsigned)time(NULL));
p
利用rand()函數(shù)產(chǎn)生隨機(jī)數(shù)字,rand()%n產(chǎn)生小于n的隨機(jī)數(shù),然后交換。
運(yùn)行的結(jié)果:
#include
#include
intmain()
{
intnbs
利用rand()函數(shù)產(chǎn)生隨機(jī)數(shù)字,rand()%n產(chǎn)生小于n的隨機(jī)數(shù),然后交換。
擴(kuò)展資料
C語言排序法
在一層循環(huán)找出最小數(shù)的下標(biāo),該下標(biāo)用min保存,直到比較完整個數(shù)組,即可找到最小的數(shù),然后將該數(shù)放入數(shù)組的第一位。
這樣只能排好一個元素,于是需要再嵌套一層外層循環(huán)即可排好所有元素。第二次循環(huán)就不用再比較第一個元素了,因?yàn)榈谝粋€元素已經(jīng)排好,依次類推,每一次循環(huán)就會排好一個,進(jìn)行n-1次循環(huán)即可排好所有元素。
隨機(jī)函數(shù)就是產(chǎn)生數(shù)的函數(shù),c語言里有rand(),srand()等函數(shù)。
用法
#include
#include
#include
void main( void )
{
int i,k;
srand( (unsigned)time( NULL ) ); //用系統(tǒng)時間當(dāng)種子,對隨機(jī)函數(shù)進(jìn)行初始化
for( i = 0; i 10;i++ )
{
k=rand()%100; //產(chǎn)生各個隨機(jī)數(shù)
printf( " k=%d/n", k );
}
}
詳述
rand() srand() 頭文件為#include
標(biāo)準(zhǔn)C庫中函數(shù)rand()可以生成0~RAND_MAX之間的一個隨機(jī)數(shù),其中RAND_MAX 是stdlib.h 中定義的一個整數(shù),它與系統(tǒng)有關(guān)。
rand()函數(shù)沒有輸入?yún)?shù),直接通過表達(dá)式rand()來引用,rand()%n是產(chǎn)生的隨機(jī)數(shù)對n取余,起到了取0到n-1之間隨機(jī)數(shù)的作用;
例如可以用下面的語句來打印兩個隨機(jī)數(shù): printf("Random numbers are: %i %i/n",rand(),rand());
因?yàn)閞and()函數(shù)是按指定的順序來產(chǎn)生整數(shù),而未指定運(yùn)行的種子,所以rand()每次使用的都是同一個種子來產(chǎn)生隨機(jī)數(shù)序列,因此每次執(zhí)行上面的語句都打印相同的兩個值,所以說C語言的隨機(jī)并不是正真意義上的隨機(jī)。
為了時程序在每次執(zhí)行時都能生成一個新序列的隨機(jī)值,我們通常通過為隨機(jī)數(shù)生成器提供一粒新的隨機(jī)種子。函數(shù) srand()(來自stdlib.h)可以為隨機(jī)數(shù)生成器播散種子。只要種子不同rand()函數(shù)就會產(chǎn)生不同的隨機(jī)數(shù)序列。srand()稱為隨機(jī)數(shù)生成器的初始化器。
srand( (unsigned)time( NULL ) ); 用系統(tǒng)時間當(dāng)種子,對隨機(jī)函數(shù)進(jìn)行初始化,每次的系統(tǒng)時間不同,所以種子也就不同,產(chǎn)生的隨機(jī)數(shù)序列也就不同。
c語言中產(chǎn)生隨機(jī)數(shù)的相關(guān)函數(shù)主要包括srand和rand函數(shù),兩者配合生成隨機(jī)數(shù)據(jù),測試代碼如下,
#includestdio.h
#include stdlib.h
#include time.h
void main()
{
int i=0,j=0;
int p[5][5]={0};
srand(time(NULL));
for(i=0;i5;i++)
for(j=0;j5;j++)
p[i][j]=rand()%100+1;//產(chǎn)生1-100的隨機(jī)數(shù)存入數(shù)組p中
printf("二維數(shù)組p為:\n");
for(i=0;i5;i++)
{
for(j=0;j5;j++)
printf("%d\t",p[i][j]);
printf("\n");
}
}
一般srand和rand配合使用產(chǎn)生偽隨機(jī)數(shù)序列。rand函數(shù)在產(chǎn)生隨機(jī)數(shù)前,需要系統(tǒng)提供的生成偽隨機(jī)數(shù)序列的種子,rand根據(jù)這個種子的值產(chǎn)生一系列隨機(jī)數(shù)。如果系統(tǒng)提供的種子沒有變化,每次調(diào)用rand函數(shù)生成的偽隨機(jī)數(shù)序列都是一樣的。srand(unsigned seed)通過參數(shù)seed改變系統(tǒng)提供的種子值,從而可以使得每次調(diào)用rand函數(shù)生成的偽隨機(jī)數(shù)序列不同,從而實(shí)現(xiàn)真正意義上的“隨機(jī)”。通??梢岳孟到y(tǒng)時間來改變系統(tǒng)的種子值,即srand(time(NULL)),可以為rand函數(shù)提供不同的種子值,進(jìn)而產(chǎn)生不同的隨機(jī)數(shù)序列。