c語言生成10個1~100隨機數(shù) C語言產(chǎn)生不重復的隨機數(shù)?
C語言產(chǎn)生不重復的隨機數(shù)?用一個數(shù)字組合一個隨機數(shù),一個數(shù)組代表記錄的隨機數(shù);例如,random 0-8生成一個隨機的8位組,數(shù)組中的每個項都不重復;例如:intray[8]intraryindex[
C語言產(chǎn)生不重復的隨機數(shù)?
用一個數(shù)字組合一個隨機數(shù),一個數(shù)組代表記錄的隨機數(shù);例如,random 0-8生成一個隨機的8位組,數(shù)組中的每個項都不重復;例如:intray[8]intraryindex[8]={0,0,0,0,0,0}intk=0srand(100),而(K<8){intq=rand()%8 1If(arrayindex[Q-1]==1){continue}數(shù)組[k]=qarrayindex[Q-1]=1K}展開數(shù)據(jù)C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言C語言隨機輸出1~20個不重復的隨機數(shù),包括<stddio。H>;包括<time。H>和include<ime。H>;包括<time。H>;包括<;t-test-test-test-lead<.H.H<.H<時間。H>時間。時間(&G)。H>>;H>;H<;H&T時間。H>;H>;H&T時間。H>;H>;H>;H>;H>;H>;H>;H>;H>;H<;全部。H、 H&T;H;H>;all a
生成的隨機數(shù)被保存,然后當獲得新的隨機數(shù)時,它將與以前保存的值進行比較。如果它已經(jīng)出現(xiàn),則丟棄并再次獲得,直到獲得不同的隨機值。
以獲取10個0到100之間的非重復隨機數(shù)為例,代碼如下:
#include
#include
#include
int main()
{
int list[10],I,J,a
srand(time(null))//設置隨機數(shù)種子。
For(I=0 I< 10 I)
]{
while(1)
{
a=rand() 0//獲取一個介于0和100之間的隨機數(shù)。
For(J=0 J< I J)
if(list[J]==a)break//檢查是否有重復項。
If(J==I)//無重復值,保存到列表。
{
list[i]=a
break]}]}
for(i=0 i< 10 i)//打印獲得的隨機數(shù)序列。
Printf(%D,”,list[i])
Printf(“n”)
返回0
}
代碼如下#include<stdio。H>int main(){int a[10],I srand((unsigned)time(0))for(I=0 I<10 I){a[I]=random() 1}return 0}
1 c語言生成隨機數(shù)函數(shù)。rand()的頭文件是stdlib。H
2。在[M,n]范圍內(nèi)生成隨機數(shù)的語句:rand()%(n-m1)M
3。生成不同隨機數(shù)范圍的方法:
保存獲得的隨機數(shù)。生成一個新的隨機數(shù)后,將其與獲得的隨機數(shù)進行比較。如果存在,則丟棄它,否則保存它。
因此,我們可以得到不同隨機數(shù)的函數(shù),最小數(shù)為M,最大數(shù)為N,總數(shù)為K,可以寫成:
void get uurand(int*a,int M,int N,int K)//結(jié)果存在于a{int i,J,t for(i=0,i< K){t=Rand()%(N-m1)M for(J=0,J< i,J) if(a[J]==t)break if(J==I)//不要重復a[I]=t//記錄隨機數(shù)。}}