C語言中隨機函數應用
可能大家都知道C語言中的隨機函數random,可是random函數並不是ANSI C標准,所以說,random函數不能在gcc,vc等編譯器下編譯通過。那麼怎麼實現C語言中的隨機函數呢?
除了random函數,還有一個rand函數,也是一個隨機函數,可以產生從0到rand_max的隨機數。
#include <stdio.h>
#include <stdlib.h>
int main()
{
int x;
x = rand();
printf("%d\n", x);
return 0;
}
運行上面的代碼,你會發現系統確實生成了一個隨機數,但是繼續運行多幾次,你會發現系統生成的數字還是以前那個,什麼情況,傷我感情~~
原來是因為隨機數取在C語言中采用的是固定序列,所以每次執行所取的是同一個數。
但是,仔細想想,如果要生成一大堆不一樣的隨機數,那要怎麼做啊,跪求蒼天啊啊啊啊啊啊~~~~ 那是沒有用滴,還不如靠自己~~
#include <stdio.h>
#include <time.h>
#include <stdlib.h>
int main()
{
int x;
time_t t;
srand((unsigned) time(&t));
for(int i=0; i<10; i++) {
printf("%d\n", rand()%100); //生成10個0~99的不同隨機數
}
return 0;
}
這時運行程序,會發現每次產生的隨機數都不一樣。
那麼為什麼第一個程序一樣而第二個程序不一樣呢?
第二個程序用到了一個新的函數srand,這個函數是給隨機數產生一個隨機種子(seed),函數原型是
srand( (unsigned) time(NULL));
time的值每時每刻都不同。所以種子不同,所以,產生的隨機數也不同。
所以說,要想產生不同的隨機數,在使用rand之前需要先調用srand
由於rand產生的隨機數從0到rand_max,而rand_max是一個很大的數,那麼如何產生從X~Y的數呢?
從X到Y,有Y-X+1個數,所以要產生從X到Y的數,只需要這樣寫:
k=rand()%(Y-X+1)+X;
這樣,就可以產生你想要的任何范圍內的隨機數了。
C++ Primer Plus 第6版 中文版 清晰有書簽PDF+源代碼 http://www.linuxidc.com/Linux/2014-05/101227.htm
讀C++ Primer 之構造函數陷阱 http://www.linuxidc.com/Linux/2011-08/40176.htm
讀C++ Primer 之智能指針 http://www.linuxidc.com/Linux/2011-08/40177.htm
讀C++ Primer 之句柄類 http://www.linuxidc.com/Linux/2011-08/40175.htm
將C語言梳理一下,分布在以下10個章節中: