c語言如何設(shè)置隨機(jī)數(shù)及逐行解析
一.產(chǎn)生隨機(jī)數(shù)
#include<stdio.h> #include<stdlib.h> #include<time.h> int main() { int n = 0; srand((unsigned int)time(NULL)); n = rand(); printf("產(chǎn)生一個隨機(jī)數(shù) %d", n); return 0; }
運(yùn)行結(jié)果
二.逐行解析
1.rand()函數(shù)
在我的MSDN里,rand()函數(shù)的返回值是int,頭文件是stdlib.h
這句話的意思是:rand函數(shù)返回一個偽隨機(jī)數(shù),如果超出范圍,則返回錯誤。rand的范圍是0 到RAND_MAX(0到32767)
這里值得注意的是什么是偽隨機(jī),下面舉個例子
我們不難看出雖然打印隨機(jī)數(shù),但每次打印的隨機(jī)數(shù)都一樣,所以怎么辦呢?我們就需要一個隨機(jī)數(shù)種子strand啦
2.srand()函數(shù)
srand的返回值是void,里面?zhèn)鲄⑿枰粋€unsigned int類型的seed(種子),我們可以看出其實(shí)這就是一個設(shè)置種子的函數(shù),那么我們設(shè)置什么種子呢?
因?yàn)槲覀兿胍碾S機(jī)數(shù)時時刻刻都要改變,那么毫無疑問就時間是在無時無刻都在改變的,所以我們設(shè)置一個時間種子
3.time()函數(shù)
time函數(shù)的返回值類型是(time_t),但我們要按照srand函數(shù)的要求將其強(qiáng)制轉(zhuǎn)化為(unsigned int)。它的頭文件是time.h。它所需要的參數(shù)是一個指針,但我們并不需要給它傳參,所以我們用(NULL)
time函數(shù)返回的值是每時每秒,所以它的值是變化的
最終我們就寫出了一個時間種子srand((unsigned int)time(NULL))
三.生成有范圍的隨機(jī)數(shù)
有時候,隨機(jī)數(shù)生成的范圍太大了,我們該怎么縮小它的范圍呢?
由此不難看出其實(shí)我們需要哪個范圍,只需要rand()%n,就可以了
原理也很簡單,一個隨機(jī)數(shù)%100那么它的值就會是0-99
總結(jié)
到此這篇關(guān)于c語言如何設(shè)置隨機(jī)數(shù)及逐行解析的文章就介紹到這了,更多相關(guān)c語言設(shè)置隨機(jī)數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- C語言/C++中如何產(chǎn)生隨機(jī)數(shù)
- C語言中用于產(chǎn)生隨機(jī)數(shù)的函數(shù)使用方法總結(jié)
- c語言生成隨機(jī)數(shù)的方法(獲得一組不同的隨機(jī)數(shù))
- C語言/C++如何生成隨機(jī)數(shù)
- C語言中隨機(jī)數(shù)rand()函數(shù)詳解
- C語言隨機(jī)數(shù)生成教程(rand和srand用法)
- 使用c語言生成隨機(jī)數(shù)的示例分享
- C語言連續(xù)生成隨機(jī)數(shù)的實(shí)現(xiàn)方法
- C語言的隨機(jī)數(shù)rand()函數(shù)詳解
- C語言編程中生成隨機(jī)數(shù)的入門教程
相關(guān)文章
c++ vector(向量)使用方法詳解(順序訪問vector的多種方式)
vector是向量類型,它可以容納許多類型的數(shù)據(jù),如若干個整數(shù),所以稱其為容器,本文介紹一下使用方法2013-12-12C語言數(shù)據(jù)結(jié)構(gòu)之模式匹配字符串定位問題
這篇文章主要介紹了C語言數(shù)據(jù)結(jié)構(gòu)之模式匹配字符串定位問題的相關(guān)資料,希望通過本文能幫助到大家,讓大家理解這部分內(nèi)容,需要的朋友可以參考下2017-10-10C語言用函數(shù)實(shí)現(xiàn)反彈球消磚塊
這篇文章主要為大家詳細(xì)介紹了C語言用函數(shù)實(shí)現(xiàn)反彈球消磚塊,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-05-05