c語言如何設置隨機數(shù)及逐行解析
一.產生隨機數(shù)
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
int main()
{
int n = 0;
srand((unsigned int)time(NULL));
n = rand();
printf("產生一個隨機數(shù) %d", n);
return 0;
}運行結果

二.逐行解析

1.rand()函數(shù)

在我的MSDN里,rand()函數(shù)的返回值是int,頭文件是stdlib.h

這句話的意思是:rand函數(shù)返回一個偽隨機數(shù),如果超出范圍,則返回錯誤。rand的范圍是0 到RAND_MAX(0到32767)
這里值得注意的是什么是偽隨機,下面舉個例子



我們不難看出雖然打印隨機數(shù),但每次打印的隨機數(shù)都一樣,所以怎么辦呢?我們就需要一個隨機數(shù)種子strand啦
2.srand()函數(shù)

srand的返回值是void,里面?zhèn)鲄⑿枰粋€unsigned int類型的seed(種子),我們可以看出其實這就是一個設置種子的函數(shù),那么我們設置什么種子呢?
因為我們想要的隨機數(shù)時時刻刻都要改變,那么毫無疑問就時間是在無時無刻都在改變的,所以我們設置一個時間種子
3.time()函數(shù)

time函數(shù)的返回值類型是(time_t),但我們要按照srand函數(shù)的要求將其強制轉化為(unsigned int)。它的頭文件是time.h。它所需要的參數(shù)是一個指針,但我們并不需要給它傳參,所以我們用(NULL)

time函數(shù)返回的值是每時每秒,所以它的值是變化的
最終我們就寫出了一個時間種子srand((unsigned int)time(NULL))
三.生成有范圍的隨機數(shù)
有時候,隨機數(shù)生成的范圍太大了,我們該怎么縮小它的范圍呢?



由此不難看出其實我們需要哪個范圍,只需要rand()%n,就可以了
原理也很簡單,一個隨機數(shù)%100那么它的值就會是0-99
總結
到此這篇關于c語言如何設置隨機數(shù)及逐行解析的文章就介紹到這了,更多相關c語言設置隨機數(shù)內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
C語言實現(xiàn)交換排序算法(冒泡,快速排序)的示例代碼
這篇文章主要為大家詳細介紹了如何利用C語言實現(xiàn)交換排序算法(冒泡排序、快速排序),文中的示例代碼講解詳細,感興趣的小伙伴可以了解一下2022-07-07

