概率的問題:使用遞歸與多次試驗(yàn)?zāi)M的分析
多次枚舉:
實(shí)例1
口袋中有5只紅球,4只白球。隨機(jī)從口袋中取出3個(gè)球,取出1個(gè)紅球2個(gè)白球的概率
<SPAN style="FONT-SIZE: 18px"> srand( (unsigned)time( NULL ) );
int n = 0;
for(int i=0; i<100000; i++)
{
char x[] = {1, 1, 1, 1, 1, 2, 2, 2, 2};//5個(gè)紅球用5個(gè)1表示 4個(gè)白球用4個(gè)2表示
int a = 0; // 取到的紅球的數(shù)目
int b = 0; // 取到的白球的數(shù)目
for(int j=0; j<3; j++) //取3個(gè)球進(jìn)行3次循環(huán)
{
int k = rand() % (9-j); //下標(biāo)的確定 確定范圍 9-j 是重點(diǎn)
if(x[k]==1)
a++;
else
b++;
x[k] = x[9-j-1]; //將取出數(shù)向后移動(dòng)
}
if(a==1 && b==2) n++;//取出1個(gè)紅球2個(gè)白球時(shí)進(jìn)行計(jì)數(shù)
}
printf("概率=%f\n", n/100000.0*100);</SPAN>
實(shí)例2
<SPAN style="FONT-SIZE: 18px">#define N 30
......
int a[N];
srand( time( NULL ) );
int n = 0;
for(int k=0; k<10000; k++)
{
for(int i=0; i<N; i++)
a[i] = rand() % 365;
bool tag = false; // 假設(shè)沒有相同
for(i=1; i<N; i++)
{
for(int j=0; j<i; j++)
{
if(a[i]==a[j])
{
tag = true;
break;
}
}
if(tag) break;
}
if(tag) n++;
}
printf("%f\n", 1.0 * n / 10000 * 100);
</SPAN>
遞歸:
某個(gè)袋子中有紅球m個(gè),白球n個(gè)?,F(xiàn)在要從中取出x個(gè)球。紅球數(shù)目多于白球的概率
下面的代碼解決了這個(gè)問題。其中的y表示紅球至少出現(xiàn)的次數(shù)。
這與前文的問題是等價(jià)的。因?yàn)槿绻?0個(gè)球,要求紅球數(shù)大于白球數(shù),則等價(jià)于至少取出16個(gè)紅球。
<SPAN style="FONT-SIZE: 18px">/*
m: 袋中紅球的數(shù)目
n: 袋中白球的數(shù)目
x: 需要取出的數(shù)目
y: 紅球至少出現(xiàn)的次數(shù)
*/
double pro(int m, int n, int x, int y)
{
if(y>x) return 0;
if(y==0) return 1; //對(duì)y沒有要求
if(y>m) return 0;
if(x-n>y) return 1; //把白球全部取出,剩下就是紅球 紅球比至少取出還多,概率為1
double p1 = pro(m-1,n,x-1,y-1) ;
double p2 = pro(m,n-1,x-1,y);
return (double)m/(m+n) * p1 + (double)n/(m+n) * p2;
}</SPAN>
相關(guān)文章
C語言中變量與其內(nèi)存地址對(duì)應(yīng)的入門知識(shí)簡單講解
這篇文章主要介紹了C語言中變量與其內(nèi)存地址對(duì)應(yīng)的入門知識(shí)簡單講解,同時(shí)這也是掌握指針部分知識(shí)的基礎(chǔ),需要的朋友可以參考下2015-12-12C語言實(shí)現(xiàn)數(shù)獨(dú)游戲的求解
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)數(shù)獨(dú)游戲的求解,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-01-01Linux中使用C語言實(shí)現(xiàn)基于UDP協(xié)議的Socket通信示例
這篇文章主要介紹了Linux中使用C語言實(shí)現(xiàn)基于UDP協(xié)議的socket通信示例,服務(wù)器端與客戶端的功能都非?;A(chǔ),需要的朋友可以參考下2016-03-03C語言實(shí)現(xiàn)飛機(jī)訂票系統(tǒng)的完整代碼
為了免去在窗口排隊(duì)買票的麻煩,飛機(jī)訂票系統(tǒng)應(yīng)運(yùn)而生,下面這篇文章主要給大家介紹了關(guān)于C語言實(shí)現(xiàn)飛機(jī)訂票系統(tǒng)的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-06-06C++詳解默認(rèn)參數(shù)的構(gòu)造函數(shù)及簡單實(shí)例代碼
這篇文章主要介紹了 C++詳解默認(rèn)參數(shù)的構(gòu)造函數(shù)及簡單實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2017-02-02C++?Boost?ProgramOptions超詳細(xì)講解
Boost是為C++語言標(biāo)準(zhǔn)庫提供擴(kuò)展的一些C++程序庫的總稱。Boost庫是一個(gè)可移植、提供源代碼的C++庫,作為標(biāo)準(zhǔn)庫的后備,是C++標(biāo)準(zhǔn)化進(jìn)程的開發(fā)引擎之一,是為C++語言標(biāo)準(zhǔn)庫提供擴(kuò)展的一些C++程序庫的總稱2022-11-11